satengine/satserver/Engine/src/CSatCommandContainer.cpp
author hgs
Mon, 04 Oct 2010 15:57:13 +0300
changeset 51 12bc758d6a02
parent 35 6aefa3341fcc
permissions -rw-r--r--
201039
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-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:  Contains SAT commands.
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    <f32file.h>
hgs
parents:
diff changeset
    21
#include    <barsc.h>
hgs
parents:
diff changeset
    22
#include    <bautils.h>
hgs
parents:
diff changeset
    23
#include    <ecom.h>
hgs
parents:
diff changeset
    24
#include    <e32property.h>
hgs
parents:
diff changeset
    25
#include    <data_caging_path_literals.hrh>
hgs
parents:
diff changeset
    26
#include    <startupdomainpskeys.h>
hgs
parents:
diff changeset
    27
#include    <satdomainpskeys.h>
35
hgs
parents: 33
diff changeset
    28
#include    <hbtextresolversymbian.h>
33
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
#include    "MSatSystemState.h"
hgs
parents:
diff changeset
    31
#include    "TSatSystemStateFactory.h"
hgs
parents:
diff changeset
    32
#include    "MSatSystemStateChangeNotifier.h"
hgs
parents:
diff changeset
    33
#include    "CSatCommandContainer.h"
hgs
parents:
diff changeset
    34
//lint -e766 Used inside TRAP macro, lint misfunction.
hgs
parents:
diff changeset
    35
#include    "EnginePanic.h"
hgs
parents:
diff changeset
    36
#include    "TUSatAPI.h"
hgs
parents:
diff changeset
    37
#include    "MSatSSessions.h"
hgs
parents:
diff changeset
    38
#include    "MSatShellController.h"
hgs
parents:
diff changeset
    39
#include    "SatServer.hrh"
hgs
parents:
diff changeset
    40
#include    "SatLog.h"
hgs
parents:
diff changeset
    41
#include    "MSatSUiClientHandler.h"
hgs
parents:
diff changeset
    42
#include    "CSatClientServiceReq.h"
hgs
parents:
diff changeset
    43
#include    "CSatEventMonitorContainer.h"
hgs
parents:
diff changeset
    44
#include    "CSatSAPChangeObserver.h"
hgs
parents:
diff changeset
    45
#include    "CSatSSimSubscriberId.h"
hgs
parents:
diff changeset
    46
#include    "CSatBIPUtils.h"
hgs
parents:
diff changeset
    47
#include    "TSatExtErrorUtils.h"
hgs
parents:
diff changeset
    48
#include    "MSatUiSession.h"
hgs
parents:
diff changeset
    49
#include    "csatmediatoreventprovider.h"
hgs
parents:
diff changeset
    50
#include    "csatprofilechangeobserver.h"
hgs
parents:
diff changeset
    51
#include    "SATInternalPSKeys.h"
hgs
parents:
diff changeset
    52
#include    "csatmultimodeapi.h"
hgs
parents:
diff changeset
    53
#include    "csatsactivewrapper.h"
hgs
parents:
diff changeset
    54
35
hgs
parents: 33
diff changeset
    55
_LIT( KResourceDrive, "z:\\resource\\qt\\translations" );
hgs
parents: 33
diff changeset
    56
_LIT( KSatServerRsc, "satapp_");
hgs
parents: 33
diff changeset
    57
_LIT( KSatLogTitle, "txt_simatk_title_sim_services");
hgs
parents: 33
diff changeset
    58
_LIT( KSatCmccTitle, "txt_simatk_titlw_cmcc_sim_services");
33
hgs
parents:
diff changeset
    59
hgs
parents:
diff changeset
    60
const TUid KSatInterfaceDefinitionUid = { 0x1000f001 };
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
// Important plugins UIDs. These are started on startup
hgs
parents:
diff changeset
    64
// Implementation UID is from the <plugin>.rss
hgs
parents:
diff changeset
    65
const TUid KSetUpEventListUid = { 0x10202993 };
hgs
parents:
diff changeset
    66
hgs
parents:
diff changeset
    67
// ======== LOCAL FUNCTIONS ========
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    70
// CleanupPointerArray
hgs
parents:
diff changeset
    71
// Cleanup RPointerArray objects by using the cleanup stack. Function will be 
hgs
parents:
diff changeset
    72
// called when application leaves while a RPointerArray object still alive, 
hgs
parents:
diff changeset
    73
// or when CleanupStack::PopAndDestroy is explicitly called to release a 
hgs
parents:
diff changeset
    74
// RPointerArray. See CleanupStack::PushL( TCleanupItem ) for more details.
hgs
parents:
diff changeset
    75
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    76
//
hgs
parents:
diff changeset
    77
static void CleanupPointerArray( TAny* aArray )
hgs
parents:
diff changeset
    78
    {
hgs
parents:
diff changeset
    79
    LOG2( NORMAL, "SATENGINE: CSatCommandContainer::CleanupPointerArray \
hgs
parents:
diff changeset
    80
        calling array = 0x%08x", aArray )
hgs
parents:
diff changeset
    81
    
hgs
parents:
diff changeset
    82
    RImplInfoPtrArray* array = reinterpret_cast<RImplInfoPtrArray*>( aArray );
hgs
parents:
diff changeset
    83
    if ( array )
hgs
parents:
diff changeset
    84
        {
hgs
parents:
diff changeset
    85
        array->ResetAndDestroy();
hgs
parents:
diff changeset
    86
        }
hgs
parents:
diff changeset
    87
    
hgs
parents:
diff changeset
    88
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::CleanupPointerArray \
hgs
parents:
diff changeset
    89
        exiting" )
hgs
parents:
diff changeset
    90
    }
hgs
parents:
diff changeset
    91
hgs
parents:
diff changeset
    92
// ======== MEMBER FUNCTIONS ========
hgs
parents:
diff changeset
    93
hgs
parents:
diff changeset
    94
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    95
// CSatCommandContainer::NewL
hgs
parents:
diff changeset
    96
// Two-phased constructor.
hgs
parents:
diff changeset
    97
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    98
//
hgs
parents:
diff changeset
    99
CSatCommandContainer* CSatCommandContainer::NewL(
hgs
parents:
diff changeset
   100
    MSatSSessions& aSessions,
hgs
parents:
diff changeset
   101
    TSatEventMediator& aEventMediator,
hgs
parents:
diff changeset
   102
    MSatSUiClientHandler& aSatUiHandler )
hgs
parents:
diff changeset
   103
    {
hgs
parents:
diff changeset
   104
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::NewL calling" )
hgs
parents:
diff changeset
   105
hgs
parents:
diff changeset
   106
    CSatCommandContainer* self =
hgs
parents:
diff changeset
   107
        new ( ELeave ) CSatCommandContainer(
hgs
parents:
diff changeset
   108
            aSessions,
hgs
parents:
diff changeset
   109
            aEventMediator,
hgs
parents:
diff changeset
   110
            aSatUiHandler );
hgs
parents:
diff changeset
   111
hgs
parents:
diff changeset
   112
    CleanupStack::PushL( self );
hgs
parents:
diff changeset
   113
    self->ConstructL();
hgs
parents:
diff changeset
   114
    CleanupStack::Pop( self );
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::NewL exiting" )
hgs
parents:
diff changeset
   117
    return self;
hgs
parents:
diff changeset
   118
    }
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   121
// CSatCommandContainer::~CSatCommandContainer
hgs
parents:
diff changeset
   122
// Destructor
hgs
parents:
diff changeset
   123
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   124
//
hgs
parents:
diff changeset
   125
CSatCommandContainer::~CSatCommandContainer()
hgs
parents:
diff changeset
   126
    {
hgs
parents:
diff changeset
   127
    LOG( NORMAL,
hgs
parents:
diff changeset
   128
        "SATENGINE: CSatCommandContainer::~CSatCommandContainer calling" )
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
    // Stop and Delete all command handlers
hgs
parents:
diff changeset
   131
    StopCommandHandlers();
hgs
parents:
diff changeset
   132
hgs
parents:
diff changeset
   133
    if ( iUSatAPI )
hgs
parents:
diff changeset
   134
        {
hgs
parents:
diff changeset
   135
        iUSatAPI->Close();
hgs
parents:
diff changeset
   136
        delete iUSatAPI;
hgs
parents:
diff changeset
   137
        iUSatAPI = NULL;
hgs
parents:
diff changeset
   138
        }
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
    if ( iServiceReqs )
hgs
parents:
diff changeset
   141
        {
hgs
parents:
diff changeset
   142
        iServiceReqs->Reset();
hgs
parents:
diff changeset
   143
        delete iServiceReqs;
hgs
parents:
diff changeset
   144
        iServiceReqs = NULL;
hgs
parents:
diff changeset
   145
        }
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
    delete iSatAppName;
hgs
parents:
diff changeset
   148
    delete iSystemState;
hgs
parents:
diff changeset
   149
    delete iBipUtils;
hgs
parents:
diff changeset
   150
    delete iSatMediatorEvent;    
hgs
parents:
diff changeset
   151
    delete iMultiModeApi;
hgs
parents:
diff changeset
   152
    
hgs
parents:
diff changeset
   153
    delete iSapObserver;
hgs
parents:
diff changeset
   154
    delete iProfileObserver;
hgs
parents:
diff changeset
   155
hgs
parents:
diff changeset
   156
    delete iSimSubscriberId;
hgs
parents:
diff changeset
   157
    delete iEventMonitors;
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
    delete iCmdHandlers;
hgs
parents:
diff changeset
   160
    delete iStartupChangeObserver;
hgs
parents:
diff changeset
   161
hgs
parents:
diff changeset
   162
    LOG( NORMAL,
hgs
parents:
diff changeset
   163
        "SATENGINE: CSatCommandContainer::~CSatCommandContainer exiting" )
hgs
parents:
diff changeset
   164
    }
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   167
// CSatCommandContainer::StartCommandHandlersL
hgs
parents:
diff changeset
   168
// (other items were commented in a header).
hgs
parents:
diff changeset
   169
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   170
//
hgs
parents:
diff changeset
   171
void CSatCommandContainer::StartCommandHandlersL()
hgs
parents:
diff changeset
   172
    {
hgs
parents:
diff changeset
   173
    LOG( NORMAL,
hgs
parents:
diff changeset
   174
        "SATENGINE: CSatCommandContainer::StartCommandHandlersL calling" )
hgs
parents:
diff changeset
   175
hgs
parents:
diff changeset
   176
    // If in startup phase, start the rest of the commands
hgs
parents:
diff changeset
   177
    if ( iStartupPhase )
hgs
parents:
diff changeset
   178
        {
hgs
parents:
diff changeset
   179
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::StartCommandHandlersL \
hgs
parents:
diff changeset
   180
             in startup phase" )
hgs
parents:
diff changeset
   181
        // Create command handlers.
hgs
parents:
diff changeset
   182
        RImplInfoPtrArray satCommandImplementations;
hgs
parents:
diff changeset
   183
        CleanupStack::PushL( 
hgs
parents:
diff changeset
   184
            TCleanupItem( CleanupPointerArray, &satCommandImplementations ) );
hgs
parents:
diff changeset
   185
        REComSession::ListImplementationsL( KSatInterfaceDefinitionUid,
hgs
parents:
diff changeset
   186
            satCommandImplementations );
hgs
parents:
diff changeset
   187
hgs
parents:
diff changeset
   188
        // Container for commands
hgs
parents:
diff changeset
   189
        const TInt cmdCount( satCommandImplementations.Count() );
hgs
parents:
diff changeset
   190
        LOG2( NORMAL, "SATENGINE: CSatCommandContainer::StartCommandHandlersL \
hgs
parents:
diff changeset
   191
            Command handler count: %d", cmdCount )
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
        // Check are there any command implementations
hgs
parents:
diff changeset
   194
        if ( cmdCount > 0 )
hgs
parents:
diff changeset
   195
            {
hgs
parents:
diff changeset
   196
            // Check array. Should not be NULL as it is started earlier
hgs
parents:
diff changeset
   197
            if ( !iCmdHandlers )
hgs
parents:
diff changeset
   198
                {
hgs
parents:
diff changeset
   199
                LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
   200
                StartCommandHandlersL iCmdHandlers false" )
hgs
parents:
diff changeset
   201
                iCmdHandlers = new ( ELeave )
hgs
parents:
diff changeset
   202
                    CArrayPtrFlat<CSatCommandHandler>( cmdCount );
hgs
parents:
diff changeset
   203
                }
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
            // Add all found command handlers to list
hgs
parents:
diff changeset
   206
            for ( TInt i = 0; i < cmdCount; i++ )
hgs
parents:
diff changeset
   207
                {
hgs
parents:
diff changeset
   208
                const TUid KImplementationUid(
hgs
parents:
diff changeset
   209
                    satCommandImplementations[i]->ImplementationUid() );
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
                // Check important command handlers. They are already started
hgs
parents:
diff changeset
   212
                if ( KImplementationUid != KSetUpEventListUid )
hgs
parents:
diff changeset
   213
                    {
hgs
parents:
diff changeset
   214
                    CSatCommandHandler* cmd =
hgs
parents:
diff changeset
   215
                        CSatCommandHandler::NewL( KImplementationUid, this );
hgs
parents:
diff changeset
   216
                    cmd->Start();
hgs
parents:
diff changeset
   217
                    CleanupStack::PushL( cmd );
hgs
parents:
diff changeset
   218
                    iCmdHandlers->AppendL( cmd );
hgs
parents:
diff changeset
   219
                    CleanupStack::Pop( cmd );
hgs
parents:
diff changeset
   220
                    }
hgs
parents:
diff changeset
   221
                }
hgs
parents:
diff changeset
   222
            }
hgs
parents:
diff changeset
   223
        CleanupStack::PopAndDestroy( &satCommandImplementations );
hgs
parents:
diff changeset
   224
        
hgs
parents:
diff changeset
   225
        // Notify TSY about readiness i.e. all nofies are sent
hgs
parents:
diff changeset
   226
        // Done only once in startup phase
hgs
parents:
diff changeset
   227
        TInt ret = iUSatAPI->UsatClientReadyIndication();
hgs
parents:
diff changeset
   228
        LOG2( NORMAL, "SATENGINE: UsatClientReadyIndication() gives %d", ret )
hgs
parents:
diff changeset
   229
        }
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
    // Else check that there are no command handlers created and
hgs
parents:
diff changeset
   232
    // BT SAP is not active
hgs
parents:
diff changeset
   233
    else if ( !iCmdHandlers && !( SystemState().IsBtSapActive() ) )
hgs
parents:
diff changeset
   234
        {
hgs
parents:
diff changeset
   235
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::StartCommandHandlersL \
hgs
parents:
diff changeset
   236
             no command handlers created and BT SAP is not active" )
hgs
parents:
diff changeset
   237
        // This is the case when
hgs
parents:
diff changeset
   238
        // SAP is first enabled and then disabled
hgs
parents:
diff changeset
   239
        if ( !iUSatAPI->IsRSatConnected() )
hgs
parents:
diff changeset
   240
            {
hgs
parents:
diff changeset
   241
            User::LeaveIfError( iUSatAPI->Connect( *iMultiModeApi ) );
hgs
parents:
diff changeset
   242
            }
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
        // Create command handlers.
hgs
parents:
diff changeset
   245
        RImplInfoPtrArray satCommandImplementations;
hgs
parents:
diff changeset
   246
        CleanupStack::PushL( 
hgs
parents:
diff changeset
   247
            TCleanupItem( CleanupPointerArray, &satCommandImplementations ) );
hgs
parents:
diff changeset
   248
        REComSession::ListImplementationsL( KSatInterfaceDefinitionUid,
hgs
parents:
diff changeset
   249
            satCommandImplementations );
hgs
parents:
diff changeset
   250
hgs
parents:
diff changeset
   251
        // Container for commands
hgs
parents:
diff changeset
   252
        const TInt cmdCount( satCommandImplementations.Count() );
hgs
parents:
diff changeset
   253
        LOG2( NORMAL, "SATENGINE: CSatCommandContainer::StartCommandHandlersL \
hgs
parents:
diff changeset
   254
            Command handler count: %d", cmdCount )
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
        // Check are there any command implementations
hgs
parents:
diff changeset
   257
        if ( cmdCount > 0 )
hgs
parents:
diff changeset
   258
            {
hgs
parents:
diff changeset
   259
            iCmdHandlers =
hgs
parents:
diff changeset
   260
                new ( ELeave ) CArrayPtrFlat<CSatCommandHandler>( cmdCount );
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
            // Add all found command handlers to list
hgs
parents:
diff changeset
   263
            for ( TInt i = 0; i < cmdCount; i++ )
hgs
parents:
diff changeset
   264
                {
hgs
parents:
diff changeset
   265
                const TUid KImplementationUid(
hgs
parents:
diff changeset
   266
                    satCommandImplementations[i]->ImplementationUid() );
hgs
parents:
diff changeset
   267
                CSatCommandHandler* cmd =
hgs
parents:
diff changeset
   268
                    CSatCommandHandler::NewL( KImplementationUid, this );
hgs
parents:
diff changeset
   269
                cmd->Start();
hgs
parents:
diff changeset
   270
                CleanupStack::PushL( cmd );
hgs
parents:
diff changeset
   271
                iCmdHandlers->AppendL( cmd );
hgs
parents:
diff changeset
   272
                CleanupStack::Pop( cmd );
hgs
parents:
diff changeset
   273
                }
hgs
parents:
diff changeset
   274
            }
hgs
parents:
diff changeset
   275
        else
hgs
parents:
diff changeset
   276
            {
hgs
parents:
diff changeset
   277
            LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
   278
            StartCommandHandlersL No commands found" )
hgs
parents:
diff changeset
   279
            // No commands, remove SAT Icon from shell
hgs
parents:
diff changeset
   280
            iSatUiHandler.ShellController().RemoveSatUiL();
hgs
parents:
diff changeset
   281
            }
hgs
parents:
diff changeset
   282
        CleanupStack::PopAndDestroy( &satCommandImplementations );
hgs
parents:
diff changeset
   283
        }
hgs
parents:
diff changeset
   284
    else
hgs
parents:
diff changeset
   285
        {
hgs
parents:
diff changeset
   286
        LOG( NORMAL, " Not starting any command handlers" )
hgs
parents:
diff changeset
   287
        }
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
    // Create SAP State observer.
hgs
parents:
diff changeset
   290
    if ( !iSapObserver )
hgs
parents:
diff changeset
   291
        {
hgs
parents:
diff changeset
   292
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::StartCommandHandlersL \
hgs
parents:
diff changeset
   293
        iSapObserver false" )
hgs
parents:
diff changeset
   294
        // Create SAP change observer only if there are command handlers.
hgs
parents:
diff changeset
   295
        iSapObserver = CSatSAPChangeObserver::NewL( *this );
hgs
parents:
diff changeset
   296
        }
hgs
parents:
diff changeset
   297
hgs
parents:
diff changeset
   298
    // Create Profile change observer.
hgs
parents:
diff changeset
   299
    if ( !iProfileObserver )
hgs
parents:
diff changeset
   300
        {
hgs
parents:
diff changeset
   301
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::StartCommandHandlersL \
hgs
parents:
diff changeset
   302
        iProfileObserver false" )
hgs
parents:
diff changeset
   303
        iProfileObserver = CSatProfileChangeObserver::NewL( *this );
hgs
parents:
diff changeset
   304
        }
hgs
parents:
diff changeset
   305
hgs
parents:
diff changeset
   306
    LOG( NORMAL,
hgs
parents:
diff changeset
   307
        "SATENGINE: CSatCommandContainer::StartCommandHandlersL exiting" )
hgs
parents:
diff changeset
   308
    }
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   311
// CSatCommandContainer::StopCommandHandlersL
hgs
parents:
diff changeset
   312
// (other items were commented in a header).
hgs
parents:
diff changeset
   313
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   314
//
hgs
parents:
diff changeset
   315
void CSatCommandContainer::StopCommandHandlers()
hgs
parents:
diff changeset
   316
    {
hgs
parents:
diff changeset
   317
    LOG( NORMAL,
hgs
parents:
diff changeset
   318
        "SATENGINE: CSatCommandContainer::StopCommandHandlers calling" )
hgs
parents:
diff changeset
   319
hgs
parents:
diff changeset
   320
    if ( iCmdHandlers )
hgs
parents:
diff changeset
   321
        {
hgs
parents:
diff changeset
   322
         // Remove every command handler from event observers
hgs
parents:
diff changeset
   323
        const TInt count( iCmdHandlers->Count() );
hgs
parents:
diff changeset
   324
        LOG2( NORMAL, "SATENGINE: CSatCommandContainer::StopCommandHandlers \
hgs
parents:
diff changeset
   325
              Command handler count: %d", count )
hgs
parents:
diff changeset
   326
        for ( TInt j = 0; j < count; j++ )
hgs
parents:
diff changeset
   327
            {
hgs
parents:
diff changeset
   328
            CSatCommandHandler* cmd = iCmdHandlers->At( j );
hgs
parents:
diff changeset
   329
            UnregisterEventObserver( cmd );
hgs
parents:
diff changeset
   330
            }
hgs
parents:
diff changeset
   331
hgs
parents:
diff changeset
   332
        // Delete command handlers
hgs
parents:
diff changeset
   333
        iCmdHandlers->ResetAndDestroy();
hgs
parents:
diff changeset
   334
hgs
parents:
diff changeset
   335
        delete iCmdHandlers;
hgs
parents:
diff changeset
   336
        iCmdHandlers = NULL;
hgs
parents:
diff changeset
   337
        }
hgs
parents:
diff changeset
   338
hgs
parents:
diff changeset
   339
    // This must be called when all ECom Plug-Ins has been deleted. Otherwise
hgs
parents:
diff changeset
   340
    // there might be memory leaks.
hgs
parents:
diff changeset
   341
    REComSession::FinalClose();
hgs
parents:
diff changeset
   342
hgs
parents:
diff changeset
   343
    // Reset ClientService request handlers since there are no command handlers
hgs
parents:
diff changeset
   344
    // to handle client responses. If SAT UI / Proactive command is executing
hgs
parents:
diff changeset
   345
    // while Bluetooth SAP is enabled, SAT UI sends ClientResponse and that must
hgs
parents:
diff changeset
   346
    // be preveted
hgs
parents:
diff changeset
   347
    if ( iServiceReqs )
hgs
parents:
diff changeset
   348
        {
hgs
parents:
diff changeset
   349
        iServiceReqs->Reset();
hgs
parents:
diff changeset
   350
        }
hgs
parents:
diff changeset
   351
hgs
parents:
diff changeset
   352
    // Close all reserved BIP Data channels
hgs
parents:
diff changeset
   353
    if ( iBipUtils )
hgs
parents:
diff changeset
   354
        {
hgs
parents:
diff changeset
   355
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::StopCommandHandlers \
hgs
parents:
diff changeset
   356
        iBipUtils true" )
hgs
parents:
diff changeset
   357
        iBipUtils->CloseAllChannels();
hgs
parents:
diff changeset
   358
        }
hgs
parents:
diff changeset
   359
hgs
parents:
diff changeset
   360
    // Cancel all event monitors
hgs
parents:
diff changeset
   361
    if ( iEventMonitors )
hgs
parents:
diff changeset
   362
        {
hgs
parents:
diff changeset
   363
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::StopCommandHandlers \
hgs
parents:
diff changeset
   364
        iEventMonitors true" )
hgs
parents:
diff changeset
   365
        iEventMonitors->CancelAllMonitors();
hgs
parents:
diff changeset
   366
        }
hgs
parents:
diff changeset
   367
hgs
parents:
diff changeset
   368
#ifdef SAT_USE_DUMMY_TSY
hgs
parents:
diff changeset
   369
    // Close ATSY. This is needed when testin BT SAP in emulator
hgs
parents:
diff changeset
   370
    if ( iUSatAPI )
hgs
parents:
diff changeset
   371
        {
hgs
parents:
diff changeset
   372
        iUSatAPI->Close();
hgs
parents:
diff changeset
   373
        }
hgs
parents:
diff changeset
   374
#endif
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
    LOG( NORMAL,
hgs
parents:
diff changeset
   377
        "SATENGINE: CSatCommandContainer::StopCommandHandlers exiting" )
hgs
parents:
diff changeset
   378
    }
hgs
parents:
diff changeset
   379
hgs
parents:
diff changeset
   380
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   381
// CSatCommandContainer::Event
hgs
parents:
diff changeset
   382
// (other items were commented in a header).
hgs
parents:
diff changeset
   383
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   384
//
hgs
parents:
diff changeset
   385
void CSatCommandContainer::Event( TInt aEvent )
hgs
parents:
diff changeset
   386
    {
hgs
parents:
diff changeset
   387
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::Event calling" )
hgs
parents:
diff changeset
   388
hgs
parents:
diff changeset
   389
    if ( MSatUtils::ECmccSimDetected == aEvent )
hgs
parents:
diff changeset
   390
        {
hgs
parents:
diff changeset
   391
        LOG( NORMAL, "SATENGINE:   Event: ECmccSimDetected" )
hgs
parents:
diff changeset
   392
        iIsCmccSim = ETrue;
hgs
parents:
diff changeset
   393
hgs
parents:
diff changeset
   394
        // Update default name read in ConstructL.
35
hgs
parents: 33
diff changeset
   395
        TRAPD( err, CreateSatAppNameL( KSatCmccTitle ) );
33
hgs
parents:
diff changeset
   396
        LOG2( NORMAL, "SATENGINE:   Error: %i", err )
hgs
parents:
diff changeset
   397
        if ( KErrNone == err )
hgs
parents:
diff changeset
   398
            {
hgs
parents:
diff changeset
   399
            // Notify application name update.
hgs
parents:
diff changeset
   400
            NotifyEvent( EApplNameUpdated );
hgs
parents:
diff changeset
   401
            }
hgs
parents:
diff changeset
   402
        }
hgs
parents:
diff changeset
   403
    else if ( MSatUtils::ESatUiClosed == aEvent )
hgs
parents:
diff changeset
   404
        {
hgs
parents:
diff changeset
   405
        LOG( NORMAL, "SATENGINE:   Event: ESatUiClosed" )
hgs
parents:
diff changeset
   406
        // Reset service requests. If this is not done,
hgs
parents:
diff changeset
   407
        // Some command may try to send data to UiClient,
hgs
parents:
diff changeset
   408
        // even if there is no request.
hgs
parents:
diff changeset
   409
        const TInt reqs( iServiceReqs->Count() );
hgs
parents:
diff changeset
   410
        LOG2( NORMAL, "SATENGINE: CSatCommandContainer::Event reqs: %i", 
hgs
parents:
diff changeset
   411
              reqs )
hgs
parents:
diff changeset
   412
        for ( TInt i = 0; i < reqs; i++ )
hgs
parents:
diff changeset
   413
            {
hgs
parents:
diff changeset
   414
            iServiceReqs->At( i )->Reset();
hgs
parents:
diff changeset
   415
            }
hgs
parents:
diff changeset
   416
        }
hgs
parents:
diff changeset
   417
    else
hgs
parents:
diff changeset
   418
        {
hgs
parents:
diff changeset
   419
        LOG( NORMAL, "SATENGINE:   Unexpected event" )
hgs
parents:
diff changeset
   420
        }
hgs
parents:
diff changeset
   421
hgs
parents:
diff changeset
   422
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::Event exiting" )
hgs
parents:
diff changeset
   423
    }
hgs
parents:
diff changeset
   424
hgs
parents:
diff changeset
   425
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   426
// CSatCommandContainer::NotifyUiEvent
hgs
parents:
diff changeset
   427
// (other items were commented in a header).
hgs
parents:
diff changeset
   428
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   429
//
hgs
parents:
diff changeset
   430
void CSatCommandContainer::NotifyUiEvent(
hgs
parents:
diff changeset
   431
    TInt aEventId, TInt aEventStatus, TInt aEventError )
hgs
parents:
diff changeset
   432
    {
hgs
parents:
diff changeset
   433
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::NotifyUiEvent calling" )
hgs
parents:
diff changeset
   434
hgs
parents:
diff changeset
   435
    MSatUiSession* session = iSatUiHandler.UiSession();
hgs
parents:
diff changeset
   436
    if ( session )
hgs
parents:
diff changeset
   437
        {
hgs
parents:
diff changeset
   438
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::NotifyUiEvent \
hgs
parents:
diff changeset
   439
        session" )
hgs
parents:
diff changeset
   440
        session->UiEventNotification( aEventId, aEventStatus, aEventError );
hgs
parents:
diff changeset
   441
        session = NULL;
hgs
parents:
diff changeset
   442
        }
hgs
parents:
diff changeset
   443
hgs
parents:
diff changeset
   444
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::NotifyUiEvent exiting" )
hgs
parents:
diff changeset
   445
    }
hgs
parents:
diff changeset
   446
hgs
parents:
diff changeset
   447
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   448
// CSatCommandContainer::USatAPI
hgs
parents:
diff changeset
   449
// (other items were commented in a header).
hgs
parents:
diff changeset
   450
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   451
//
hgs
parents:
diff changeset
   452
MSatApi& CSatCommandContainer::USatAPI()
hgs
parents:
diff changeset
   453
    {
hgs
parents:
diff changeset
   454
    LOG( DETAILED, "SATENGINE: CSatCommandContainer::USatAPI calling" )
hgs
parents:
diff changeset
   455
hgs
parents:
diff changeset
   456
    __ASSERT_ALWAYS( iUSatAPI, PanicSatEngine( ESatEngineNullPointer ) );
hgs
parents:
diff changeset
   457
hgs
parents:
diff changeset
   458
    LOG( DETAILED, "SATENGINE: CSatCommandContainer::USatAPI exiting" )
hgs
parents:
diff changeset
   459
    return *iUSatAPI;
hgs
parents:
diff changeset
   460
    }
hgs
parents:
diff changeset
   461
hgs
parents:
diff changeset
   462
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   463
// CSatCommandContainer::SystemState
hgs
parents:
diff changeset
   464
// (other items were commented in a header).
hgs
parents:
diff changeset
   465
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   466
//
hgs
parents:
diff changeset
   467
MSatSystemState& CSatCommandContainer::SystemState()
hgs
parents:
diff changeset
   468
    {
hgs
parents:
diff changeset
   469
    LOG( NORMAL,
hgs
parents:
diff changeset
   470
        "SATENGINE: CSatCommandContainer::SystemState calling-exiting" )
hgs
parents:
diff changeset
   471
    return *iSystemState;
hgs
parents:
diff changeset
   472
    }
hgs
parents:
diff changeset
   473
hgs
parents:
diff changeset
   474
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   475
// CSatCommandContainer::SatUiHandler
hgs
parents:
diff changeset
   476
// (other items were commented in a header).
hgs
parents:
diff changeset
   477
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   478
//
hgs
parents:
diff changeset
   479
MSatSUiClientHandler& CSatCommandContainer::SatUiHandler()
hgs
parents:
diff changeset
   480
    {
hgs
parents:
diff changeset
   481
    LOG( NORMAL,
hgs
parents:
diff changeset
   482
        "SATENGINE: CSatCommandContainer::SatUiHandler calling-exiting" )
hgs
parents:
diff changeset
   483
    return iSatUiHandler;
hgs
parents:
diff changeset
   484
    }
hgs
parents:
diff changeset
   485
hgs
parents:
diff changeset
   486
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   487
// CSatCommandContainer::RegisterL
hgs
parents:
diff changeset
   488
// Forwards the registeration to TSatEventMediator
hgs
parents:
diff changeset
   489
// (other items were commented in a header).
hgs
parents:
diff changeset
   490
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   491
//
hgs
parents:
diff changeset
   492
void CSatCommandContainer::RegisterL(
hgs
parents:
diff changeset
   493
    MSatEventObserver* aObserver, // Event observer
hgs
parents:
diff changeset
   494
    TSatEvent aEvent ) // Event which is observerd
hgs
parents:
diff changeset
   495
    {
hgs
parents:
diff changeset
   496
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::RegisterL calling" )
hgs
parents:
diff changeset
   497
hgs
parents:
diff changeset
   498
    iEventMediator.RegisterL( aObserver, aEvent );
hgs
parents:
diff changeset
   499
hgs
parents:
diff changeset
   500
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::RegisterL exiting" )
hgs
parents:
diff changeset
   501
    }
hgs
parents:
diff changeset
   502
hgs
parents:
diff changeset
   503
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   504
// CSatCommandContainer::NotifyEvent
hgs
parents:
diff changeset
   505
// (other items were commented in a header).
hgs
parents:
diff changeset
   506
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   507
//
hgs
parents:
diff changeset
   508
void CSatCommandContainer::NotifyEvent( TSatEvent aEvent )
hgs
parents:
diff changeset
   509
    {
hgs
parents:
diff changeset
   510
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::NotifyEvent calling" )
hgs
parents:
diff changeset
   511
hgs
parents:
diff changeset
   512
    iEventMediator.Notify( aEvent );
hgs
parents:
diff changeset
   513
hgs
parents:
diff changeset
   514
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::NotifyEvent exiting" )
hgs
parents:
diff changeset
   515
    }
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   518
// CSatCommandContainer::UnregisterEvent
hgs
parents:
diff changeset
   519
// (other items were commented in a header).
hgs
parents:
diff changeset
   520
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   521
//
hgs
parents:
diff changeset
   522
void CSatCommandContainer::UnregisterEvent(
hgs
parents:
diff changeset
   523
    MSatEventObserver* aObserver, // Observer of the event
hgs
parents:
diff changeset
   524
    TSatEvent aEvent ) // Event
hgs
parents:
diff changeset
   525
    {
hgs
parents:
diff changeset
   526
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::UnregisterEvent calling" )
hgs
parents:
diff changeset
   527
hgs
parents:
diff changeset
   528
    iEventMediator.Unregister( aObserver, aEvent );
hgs
parents:
diff changeset
   529
hgs
parents:
diff changeset
   530
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::UnregisterEvent exiting" )
hgs
parents:
diff changeset
   531
    }
hgs
parents:
diff changeset
   532
hgs
parents:
diff changeset
   533
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   534
// CSatCommandContainer::UnregisterEvent
hgs
parents:
diff changeset
   535
// (other items were commented in a header).
hgs
parents:
diff changeset
   536
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   537
//
hgs
parents:
diff changeset
   538
void CSatCommandContainer::UnregisterEventObserver(
hgs
parents:
diff changeset
   539
    MSatEventObserver* aObserver )
hgs
parents:
diff changeset
   540
    {
hgs
parents:
diff changeset
   541
    LOG( NORMAL,
hgs
parents:
diff changeset
   542
        "SATENGINE: CSatCommandContainer::UnregisterEventObserver calling" )
hgs
parents:
diff changeset
   543
hgs
parents:
diff changeset
   544
    iEventMediator.Unregister( aObserver );
hgs
parents:
diff changeset
   545
hgs
parents:
diff changeset
   546
    LOG( NORMAL,
hgs
parents:
diff changeset
   547
        "SATENGINE: CSatCommandContainer::UnregisterEventObserver exiting" )
hgs
parents:
diff changeset
   548
    }
hgs
parents:
diff changeset
   549
hgs
parents:
diff changeset
   550
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   551
// CSatCommandContainer::NumberOfExecutingCommandHandlers
hgs
parents:
diff changeset
   552
// (other items were commented in a header).
hgs
parents:
diff changeset
   553
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   554
//
hgs
parents:
diff changeset
   555
TInt CSatCommandContainer::NumberOfExecutingCommandHandlers()
hgs
parents:
diff changeset
   556
    {
hgs
parents:
diff changeset
   557
    LOG( NORMAL,
hgs
parents:
diff changeset
   558
        "SATENGINE: CSatCommandContainer::NumberOfExecutingCommandHandlers \
hgs
parents:
diff changeset
   559
        calling" )
hgs
parents:
diff changeset
   560
hgs
parents:
diff changeset
   561
    TInt result( 0 );
hgs
parents:
diff changeset
   562
    TInt count( 0 );
hgs
parents:
diff changeset
   563
    if ( iCmdHandlers )
hgs
parents:
diff changeset
   564
        {
hgs
parents:
diff changeset
   565
        LOG( NORMAL,
hgs
parents:
diff changeset
   566
        "SATENGINE: CSatCommandContainer::NumberOfExecutingCommandHandlers \
hgs
parents:
diff changeset
   567
        iCmdHandlers true" )
hgs
parents:
diff changeset
   568
        // Gets the count of command handlers
hgs
parents:
diff changeset
   569
        // if the list is already available.
hgs
parents:
diff changeset
   570
        count = iCmdHandlers->Count();
hgs
parents:
diff changeset
   571
        }
hgs
parents:
diff changeset
   572
    LOG2( NORMAL, "CSatCommandContainer::NumberOfExecutingCommandHandlers \
hgs
parents:
diff changeset
   573
          count: %i", count )
hgs
parents:
diff changeset
   574
    for ( TInt i = 0; i < count; i++ )
hgs
parents:
diff changeset
   575
        {
hgs
parents:
diff changeset
   576
        CSatCommandHandler* handler = iCmdHandlers->At( i );
hgs
parents:
diff changeset
   577
        __ASSERT_ALWAYS( handler, PanicSatEngine( ESatEngineNullPointer ) );
hgs
parents:
diff changeset
   578
hgs
parents:
diff changeset
   579
        // If command handler is not active then it has received command
hgs
parents:
diff changeset
   580
        // from sim.
hgs
parents:
diff changeset
   581
        if ( handler->IsCommandExecuting() )
hgs
parents:
diff changeset
   582
            {
hgs
parents:
diff changeset
   583
            result++;
hgs
parents:
diff changeset
   584
            }
hgs
parents:
diff changeset
   585
        }
hgs
parents:
diff changeset
   586
hgs
parents:
diff changeset
   587
    LOG2( NORMAL,
hgs
parents:
diff changeset
   588
        "SATENGINE: CSatCommandContainer::NumberOfExecutingCommandHandlers \
hgs
parents:
diff changeset
   589
        exiting: %i", result )
hgs
parents:
diff changeset
   590
    return result;
hgs
parents:
diff changeset
   591
    }
hgs
parents:
diff changeset
   592
hgs
parents:
diff changeset
   593
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   594
// CSatCommandContainer::SatAppName
hgs
parents:
diff changeset
   595
// (other items were commented in a header).
hgs
parents:
diff changeset
   596
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   597
//
hgs
parents:
diff changeset
   598
const TDesC& CSatCommandContainer::SatAppName() const
hgs
parents:
diff changeset
   599
    {
hgs
parents:
diff changeset
   600
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::SatAppName calling-exiting" )
hgs
parents:
diff changeset
   601
    return *iSatAppName;
hgs
parents:
diff changeset
   602
    }
hgs
parents:
diff changeset
   603
hgs
parents:
diff changeset
   604
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   605
// CSatCommandContainer::BipApnName
hgs
parents:
diff changeset
   606
// (other items were commented in a header).
hgs
parents:
diff changeset
   607
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   608
//
hgs
parents:
diff changeset
   609
const TDesC& CSatCommandContainer::BipApnName() const
hgs
parents:
diff changeset
   610
    {
hgs
parents:
diff changeset
   611
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::BipApnName calling-exiting" )
hgs
parents:
diff changeset
   612
    return iSatBipName;
hgs
parents:
diff changeset
   613
    }
hgs
parents:
diff changeset
   614
hgs
parents:
diff changeset
   615
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   616
// CSatCommandContainer::RestoreSatAppNameL
hgs
parents:
diff changeset
   617
// (other items were commented in a header).
hgs
parents:
diff changeset
   618
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   619
//
hgs
parents:
diff changeset
   620
void CSatCommandContainer::RestoreSatAppNameL()
hgs
parents:
diff changeset
   621
    {
hgs
parents:
diff changeset
   622
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::RestoreSatAppNameL calling" )
hgs
parents:
diff changeset
   623
    if ( !iIsCmccSim )
hgs
parents:
diff changeset
   624
        {
hgs
parents:
diff changeset
   625
        LOG( NORMAL,
hgs
parents:
diff changeset
   626
            "SATENGINE: CSatCommandContainer::RestoreSatAppNameL name reset" )
35
hgs
parents: 33
diff changeset
   627
        CreateSatAppNameL( KSatLogTitle );
33
hgs
parents:
diff changeset
   628
        }
hgs
parents:
diff changeset
   629
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::RestoreSatAppNameL exiting" )
hgs
parents:
diff changeset
   630
    }
hgs
parents:
diff changeset
   631
hgs
parents:
diff changeset
   632
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   633
// CSatCommandContainer::SetSatAppNameL
hgs
parents:
diff changeset
   634
// (other items were commented in a header).
hgs
parents:
diff changeset
   635
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   636
//
hgs
parents:
diff changeset
   637
void CSatCommandContainer::SetSatAppNameL(
hgs
parents:
diff changeset
   638
    const TDesC& aName ) // New sat app name
hgs
parents:
diff changeset
   639
    {
hgs
parents:
diff changeset
   640
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::SetSatAppNameL calling" )
hgs
parents:
diff changeset
   641
hgs
parents:
diff changeset
   642
    if ( !iIsCmccSim )
hgs
parents:
diff changeset
   643
        {
hgs
parents:
diff changeset
   644
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::SetSatAppNameL \
hgs
parents:
diff changeset
   645
        iIsCmccSim false" )
hgs
parents:
diff changeset
   646
        HBufC* temp = aName.AllocL();
hgs
parents:
diff changeset
   647
        delete iSatAppName;
hgs
parents:
diff changeset
   648
        iSatAppName = temp;
hgs
parents:
diff changeset
   649
        }
hgs
parents:
diff changeset
   650
hgs
parents:
diff changeset
   651
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::SetSatAppNameL exiting" )
hgs
parents:
diff changeset
   652
    }
hgs
parents:
diff changeset
   653
hgs
parents:
diff changeset
   654
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   655
// CSatCommandContainer::RefreshSubSessions
hgs
parents:
diff changeset
   656
// (other items were commented in a header).
hgs
parents:
diff changeset
   657
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   658
//
hgs
parents:
diff changeset
   659
const RPointerArray<MSatRefreshSubSession>&
hgs
parents:
diff changeset
   660
    CSatCommandContainer::RefreshSubSessions()
hgs
parents:
diff changeset
   661
    {
hgs
parents:
diff changeset
   662
    LOG( NORMAL,
hgs
parents:
diff changeset
   663
        "SATENGINE: CSatCommandContainer::RefreshSubSessions calling-exiting" )
hgs
parents:
diff changeset
   664
    return iSessions.RefreshSubSessions();
hgs
parents:
diff changeset
   665
    }
hgs
parents:
diff changeset
   666
hgs
parents:
diff changeset
   667
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   668
// CSatCommandContainer::RegisterServiceRequestL
hgs
parents:
diff changeset
   669
// (other items were commented in a header).
hgs
parents:
diff changeset
   670
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   671
//
hgs
parents:
diff changeset
   672
void CSatCommandContainer::RegisterServiceRequestL(
hgs
parents:
diff changeset
   673
    TSatServerRequest aRequest,
hgs
parents:
diff changeset
   674
    TSatServerRequest aResponse,
hgs
parents:
diff changeset
   675
    MSatCommand* aCommand )
hgs
parents:
diff changeset
   676
    {
hgs
parents:
diff changeset
   677
    LOG( NORMAL,
hgs
parents:
diff changeset
   678
        "SATENGINE: CSatCommandContainer::RegisterServiceRequestL calling" )
hgs
parents:
diff changeset
   679
hgs
parents:
diff changeset
   680
    // First, check is there service request handler already with the same
hgs
parents:
diff changeset
   681
    // request.If it exists, change command handler
hgs
parents:
diff changeset
   682
    const TInt reqs( iServiceReqs->Count() );
hgs
parents:
diff changeset
   683
    TBool requestHandled( EFalse );
hgs
parents:
diff changeset
   684
    LOG2( NORMAL, "CSatCommandContainer::RegisterServiceRequestL \
hgs
parents:
diff changeset
   685
          reqs: %i", reqs )
hgs
parents:
diff changeset
   686
    for ( TInt i = 0; i < reqs; i++ )
hgs
parents:
diff changeset
   687
        {
hgs
parents:
diff changeset
   688
        CSatClientServiceReq* req = iServiceReqs->At( i );
hgs
parents:
diff changeset
   689
        __ASSERT_ALWAYS( req, PanicSatEngine( ESatEngineNullPointer ) );
hgs
parents:
diff changeset
   690
hgs
parents:
diff changeset
   691
        if ( req->IsMyRequest( aRequest ) )
hgs
parents:
diff changeset
   692
            {
hgs
parents:
diff changeset
   693
            req->SetCommandHandler( aCommand );
hgs
parents:
diff changeset
   694
            requestHandled = ETrue;
hgs
parents:
diff changeset
   695
            i = reqs; // to end for-loop
hgs
parents:
diff changeset
   696
            }
hgs
parents:
diff changeset
   697
        }
hgs
parents:
diff changeset
   698
hgs
parents:
diff changeset
   699
    // Check was service request found
hgs
parents:
diff changeset
   700
    if ( !requestHandled )
hgs
parents:
diff changeset
   701
        {
hgs
parents:
diff changeset
   702
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
   703
        RegisterServiceRequestL requestHandled false" )
hgs
parents:
diff changeset
   704
        // Not found, add new
hgs
parents:
diff changeset
   705
        CSatClientServiceReq* servReq = CSatClientServiceReq::NewL( 
hgs
parents:
diff changeset
   706
            aRequest, aResponse, aCommand, *this );
hgs
parents:
diff changeset
   707
        CleanupStack::PushL( servReq );
hgs
parents:
diff changeset
   708
        iServiceReqs->AppendL( servReq );
hgs
parents:
diff changeset
   709
        CleanupStack::Pop( servReq );
hgs
parents:
diff changeset
   710
        }
hgs
parents:
diff changeset
   711
hgs
parents:
diff changeset
   712
    LOG( NORMAL,
hgs
parents:
diff changeset
   713
        "SATENGINE: CSatCommandContainer::RegisterServiceRequestL exiting" )
hgs
parents:
diff changeset
   714
    }
hgs
parents:
diff changeset
   715
hgs
parents:
diff changeset
   716
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   717
// CSatCommandContainer::ServiceRequests
hgs
parents:
diff changeset
   718
// (other items were commented in a header).
hgs
parents:
diff changeset
   719
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   720
//
hgs
parents:
diff changeset
   721
CArrayPtrFlat<CSatClientServiceReq>*
hgs
parents:
diff changeset
   722
    CSatCommandContainer::ServiceRequests()
hgs
parents:
diff changeset
   723
    {
hgs
parents:
diff changeset
   724
    LOG( NORMAL,
hgs
parents:
diff changeset
   725
        "SATENGINE: CSatCommandContainer::ServiceRequests calling-exiting" )
hgs
parents:
diff changeset
   726
    return iServiceReqs;
hgs
parents:
diff changeset
   727
    }
hgs
parents:
diff changeset
   728
hgs
parents:
diff changeset
   729
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   730
// CSatCommandContainer::EventMonitors
hgs
parents:
diff changeset
   731
// (other items were commented in a header).
hgs
parents:
diff changeset
   732
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   733
//
hgs
parents:
diff changeset
   734
MSatEventMonitorContainer* CSatCommandContainer::EventMonitors()
hgs
parents:
diff changeset
   735
    {
hgs
parents:
diff changeset
   736
    LOG( NORMAL,
hgs
parents:
diff changeset
   737
        "SATENGINE: CSatCommandContainer::EventMonitors calling-exiting" )
hgs
parents:
diff changeset
   738
    return iEventMonitors;
hgs
parents:
diff changeset
   739
    }
hgs
parents:
diff changeset
   740
hgs
parents:
diff changeset
   741
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   742
// CSatCommandContainer::SimSubscriberId
hgs
parents:
diff changeset
   743
// (other items were commented in a header).
hgs
parents:
diff changeset
   744
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   745
//
hgs
parents:
diff changeset
   746
MSatSSimSubscriberId& CSatCommandContainer::SimSubscriberId()
hgs
parents:
diff changeset
   747
    {
hgs
parents:
diff changeset
   748
    LOG( NORMAL,
hgs
parents:
diff changeset
   749
        "SATENGINE: CSatCommandContainer::SimSubscriberId calling-exiting" )
hgs
parents:
diff changeset
   750
    return *iSimSubscriberId;
hgs
parents:
diff changeset
   751
    }
hgs
parents:
diff changeset
   752
hgs
parents:
diff changeset
   753
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   754
// CSatCommandContainer::BipUtils
hgs
parents:
diff changeset
   755
// (other items were commented in a header).
hgs
parents:
diff changeset
   756
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   757
//
hgs
parents:
diff changeset
   758
MSatBIPUtils& CSatCommandContainer::BipUtils()
hgs
parents:
diff changeset
   759
    {
hgs
parents:
diff changeset
   760
    LOG( NORMAL,
hgs
parents:
diff changeset
   761
        "SATENGINE: CSatCommandContainer::BipUtils calling-exiting" )
hgs
parents:
diff changeset
   762
    return *CreateAndGetBIPUtils();
hgs
parents:
diff changeset
   763
    }
hgs
parents:
diff changeset
   764
hgs
parents:
diff changeset
   765
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   766
// CSatCommandContainer::BipEventNotifier
hgs
parents:
diff changeset
   767
// (other items were commented in a header).
hgs
parents:
diff changeset
   768
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   769
//
hgs
parents:
diff changeset
   770
MSatBIPEventNotifier& CSatCommandContainer::BipEventNotifier()
hgs
parents:
diff changeset
   771
    {
hgs
parents:
diff changeset
   772
    LOG( NORMAL,
hgs
parents:
diff changeset
   773
        "SATENGINE: CSatCommandContainer::BipEventNotifier calling-exiting" )
hgs
parents:
diff changeset
   774
    return *CreateAndGetBIPUtils();
hgs
parents:
diff changeset
   775
    }
hgs
parents:
diff changeset
   776
hgs
parents:
diff changeset
   777
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   778
// CSatCommandContainer::MultiModeApi
hgs
parents:
diff changeset
   779
// (other items were commented in a header).
hgs
parents:
diff changeset
   780
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   781
//
hgs
parents:
diff changeset
   782
MSatMultiModeApi& CSatCommandContainer::MultiModeApi()
hgs
parents:
diff changeset
   783
    {
hgs
parents:
diff changeset
   784
    LOG( NORMAL,
hgs
parents:
diff changeset
   785
        "SATENGINE: CSatCommandContainer::MultiModeApi calling-exiting" )
hgs
parents:
diff changeset
   786
    return *iMultiModeApi;
hgs
parents:
diff changeset
   787
    }
hgs
parents:
diff changeset
   788
hgs
parents:
diff changeset
   789
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   790
// CSatCommandContainer::CustomApi
hgs
parents:
diff changeset
   791
// (other items were commented in a header).
hgs
parents:
diff changeset
   792
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   793
//
hgs
parents:
diff changeset
   794
RMmCustomAPI* CSatCommandContainer::CustomApi()
hgs
parents:
diff changeset
   795
    {
hgs
parents:
diff changeset
   796
    LOG( NORMAL,
hgs
parents:
diff changeset
   797
        "SATENGINE: CSatCommandContainer::CustomApi calling-exiting" )
hgs
parents:
diff changeset
   798
    return iMultiModeApi->CustomApi();
hgs
parents:
diff changeset
   799
    }
hgs
parents:
diff changeset
   800
hgs
parents:
diff changeset
   801
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   802
// CSatCommandContainer::RaiseSatEvent
hgs
parents:
diff changeset
   803
// (other items were commented in a header).
hgs
parents:
diff changeset
   804
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   805
//
hgs
parents:
diff changeset
   806
TInt CSatCommandContainer::RaiseSatEvent( const TDesC8& aData )
hgs
parents:
diff changeset
   807
    {
hgs
parents:
diff changeset
   808
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::RaiseSatEvent calling" )
hgs
parents:
diff changeset
   809
hgs
parents:
diff changeset
   810
    CSatMediatorEventProvider* medEvent =
hgs
parents:
diff changeset
   811
        CreateAndGetSatMediatorEventProvider();
hgs
parents:
diff changeset
   812
    TInt retVal( KErrNone );
hgs
parents:
diff changeset
   813
    if ( medEvent )
hgs
parents:
diff changeset
   814
        {
hgs
parents:
diff changeset
   815
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::RaiseSatEvent \
hgs
parents:
diff changeset
   816
        medEvent true" )
hgs
parents:
diff changeset
   817
        retVal = medEvent->RaiseSatEvent( aData );
hgs
parents:
diff changeset
   818
        }
hgs
parents:
diff changeset
   819
hgs
parents:
diff changeset
   820
    LOG2( NORMAL,"SATENGINE: CSatCommandContainer::RaiseSatEvent exiting, \
hgs
parents:
diff changeset
   821
          retVal: %d", retVal )
hgs
parents:
diff changeset
   822
    return retVal;
hgs
parents:
diff changeset
   823
    }
hgs
parents:
diff changeset
   824
hgs
parents:
diff changeset
   825
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   826
// CSatCommandContainer::CoverUiSupported()
hgs
parents:
diff changeset
   827
// (other items were commented in a header).
hgs
parents:
diff changeset
   828
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   829
//
hgs
parents:
diff changeset
   830
TBool CSatCommandContainer::CoverUiSupported()
hgs
parents:
diff changeset
   831
    {
hgs
parents:
diff changeset
   832
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::CoverUiSupported calling" )
hgs
parents:
diff changeset
   833
hgs
parents:
diff changeset
   834
    CSatMediatorEventProvider* medEvent = CreateAndGetSatMediatorEventProvider();
hgs
parents:
diff changeset
   835
    TBool supported( EFalse );
hgs
parents:
diff changeset
   836
    if ( medEvent )
hgs
parents:
diff changeset
   837
        {
hgs
parents:
diff changeset
   838
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::CoverUiSupported \
hgs
parents:
diff changeset
   839
        medEvent true" )
hgs
parents:
diff changeset
   840
        supported = medEvent->CoverUiSupported();
hgs
parents:
diff changeset
   841
        }
hgs
parents:
diff changeset
   842
hgs
parents:
diff changeset
   843
    LOG2( NORMAL, "SATENGINE: CSatCommandContainer::CoverUiSupported exiting,\
hgs
parents:
diff changeset
   844
          supported: %d", supported )
hgs
parents:
diff changeset
   845
    return supported;
hgs
parents:
diff changeset
   846
    }
hgs
parents:
diff changeset
   847
hgs
parents:
diff changeset
   848
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   849
// CSatCommandContainer::CreateAsyncToSyncHelperL
hgs
parents:
diff changeset
   850
// (other items were commented in a header).
hgs
parents:
diff changeset
   851
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   852
//
hgs
parents:
diff changeset
   853
MSatAsyncToSync* CSatCommandContainer::CreateAsyncToSyncHelper()
hgs
parents:
diff changeset
   854
    {
hgs
parents:
diff changeset
   855
    MSatAsyncToSync* wrapper = new CSatSActiveWrapper();
hgs
parents:
diff changeset
   856
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
   857
            CreateAsyncToSyncHelperL calling - exiting" )
hgs
parents:
diff changeset
   858
    return wrapper;
hgs
parents:
diff changeset
   859
    }
hgs
parents:
diff changeset
   860
hgs
parents:
diff changeset
   861
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   862
// CSatCommandContainer::StateChanged
hgs
parents:
diff changeset
   863
// (other items were commented in a header).
hgs
parents:
diff changeset
   864
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   865
//
hgs
parents:
diff changeset
   866
void CSatCommandContainer::StateChanged( const TInt aValue )
hgs
parents:
diff changeset
   867
    {
hgs
parents:
diff changeset
   868
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::StateChanged calling" )
hgs
parents:
diff changeset
   869
    CheckStartupState( aValue );
hgs
parents:
diff changeset
   870
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::StateChanged exiting" )
hgs
parents:
diff changeset
   871
    }
hgs
parents:
diff changeset
   872
hgs
parents:
diff changeset
   873
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   874
// CSatCommandContainer::CSatCommandContainer
hgs
parents:
diff changeset
   875
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
   876
// might leave.
hgs
parents:
diff changeset
   877
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   878
//
hgs
parents:
diff changeset
   879
CSatCommandContainer::CSatCommandContainer(
hgs
parents:
diff changeset
   880
    MSatSSessions& aSessions,
hgs
parents:
diff changeset
   881
    TSatEventMediator& aEventMediator,
hgs
parents:
diff changeset
   882
    MSatSUiClientHandler& aSatUiHandler ) :
hgs
parents:
diff changeset
   883
    iSessions( aSessions ),
hgs
parents:
diff changeset
   884
    iEventMediator( aEventMediator ),
hgs
parents:
diff changeset
   885
    iSatUiHandler( aSatUiHandler ),
hgs
parents:
diff changeset
   886
    iSatMediatorEvent( NULL )
hgs
parents:
diff changeset
   887
    {
hgs
parents:
diff changeset
   888
    LOG( NORMAL,
hgs
parents:
diff changeset
   889
       "SATENGINE: CSatCommandContainer::CSatCommandContainer calling-exiting" )
hgs
parents:
diff changeset
   890
    }
hgs
parents:
diff changeset
   891
hgs
parents:
diff changeset
   892
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   893
// CSatCommandContainer::ConstructL
hgs
parents:
diff changeset
   894
// Symbian 2nd phase constructor can leave.
hgs
parents:
diff changeset
   895
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   896
//
hgs
parents:
diff changeset
   897
void CSatCommandContainer::ConstructL()
hgs
parents:
diff changeset
   898
    {
hgs
parents:
diff changeset
   899
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::ConstructL calling" )
hgs
parents:
diff changeset
   900
hgs
parents:
diff changeset
   901
    iIsCmccSim = EFalse;
35
hgs
parents: 33
diff changeset
   902
    CreateSatAppNameL( KSatLogTitle );
33
hgs
parents:
diff changeset
   903
hgs
parents:
diff changeset
   904
    // Register for ui events in order to keep track if user or command
hgs
parents:
diff changeset
   905
    // has launched the ui.
hgs
parents:
diff changeset
   906
    iEventMediator.RegisterL( this, MSatUtils::ESatUiClosed );
hgs
parents:
diff changeset
   907
    iEventMediator.RegisterL( this, MSatUtils::ECmccSimDetected );
hgs
parents:
diff changeset
   908
hgs
parents:
diff changeset
   909
    // Set these pointers to NULL because their value is checked
hgs
parents:
diff changeset
   910
    // before initialization...
hgs
parents:
diff changeset
   911
    iSapObserver = NULL;
hgs
parents:
diff changeset
   912
    iCmdHandlers = NULL;
hgs
parents:
diff changeset
   913
    iProfileObserver = NULL;
hgs
parents:
diff changeset
   914
hgs
parents:
diff changeset
   915
    // Create pointer array for service request handlers
hgs
parents:
diff changeset
   916
    iServiceReqs = new( ELeave )CArrayPtrFlat<CSatClientServiceReq>( 1 );
hgs
parents:
diff changeset
   917
hgs
parents:
diff changeset
   918
    iMultiModeApi = CSatMultiModeApi::NewL();
hgs
parents:
diff changeset
   919
    
hgs
parents:
diff changeset
   920
    // By default, we use extended errors
hgs
parents:
diff changeset
   921
    iMultiModeApi->RaiseErrorGranularity();
hgs
parents:
diff changeset
   922
hgs
parents:
diff changeset
   923
    iUSatAPI = new( ELeave )TUSatAPI();
hgs
parents:
diff changeset
   924
    TInt error = iUSatAPI->Connect( *iMultiModeApi );
hgs
parents:
diff changeset
   925
hgs
parents:
diff changeset
   926
    // Create SystemState.
hgs
parents:
diff changeset
   927
    iSystemState = 
hgs
parents:
diff changeset
   928
            TSatSystemStateFactory::CreateSystemStateL( *iMultiModeApi );
hgs
parents:
diff changeset
   929
hgs
parents:
diff changeset
   930
    // Create event monitor container.
hgs
parents:
diff changeset
   931
    iEventMonitors = CSatEventMonitorContainer::NewL( *iUSatAPI, *this );
hgs
parents:
diff changeset
   932
hgs
parents:
diff changeset
   933
    // Check did the conneciton to phone passed.
hgs
parents:
diff changeset
   934
    if ( KErrNone == error )
hgs
parents:
diff changeset
   935
        {
hgs
parents:
diff changeset
   936
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::ConstructL connection \
hgs
parents:
diff changeset
   937
             to phone" )
hgs
parents:
diff changeset
   938
        iStartupPhase = ETrue;
hgs
parents:
diff changeset
   939
        // Start important plugins
hgs
parents:
diff changeset
   940
        StartImportantCommandHandlersL();
hgs
parents:
diff changeset
   941
hgs
parents:
diff changeset
   942
        // Start listening system's state
hgs
parents:
diff changeset
   943
        iStartupChangeObserver =
hgs
parents:
diff changeset
   944
            TSatSystemStateFactory::CreateStartupChangeNotifierL( *this );
hgs
parents:
diff changeset
   945
        CheckStartupState( iStartupChangeObserver->GetValueInt() );
hgs
parents:
diff changeset
   946
hgs
parents:
diff changeset
   947
        if ( iStartupPhase )
hgs
parents:
diff changeset
   948
            {
hgs
parents:
diff changeset
   949
            LOG( NORMAL, "SATENGINE: CSatCommandContainer::ConstructL \
hgs
parents:
diff changeset
   950
            iStartupPhase true" )
hgs
parents:
diff changeset
   951
            iStartupChangeObserver->NotifyChangeL();
hgs
parents:
diff changeset
   952
            }
hgs
parents:
diff changeset
   953
hgs
parents:
diff changeset
   954
        }
hgs
parents:
diff changeset
   955
hgs
parents:
diff changeset
   956
    // Create Subscriber id handler.
hgs
parents:
diff changeset
   957
    iSimSubscriberId = 
hgs
parents:
diff changeset
   958
              CSatSSimSubscriberId::NewL( *iMultiModeApi, iEventMediator );
hgs
parents:
diff changeset
   959
    iSimSubscriberId->Start();
hgs
parents:
diff changeset
   960
hgs
parents:
diff changeset
   961
    // Create SatMediatorEventProvider. Will register SAT Cover UI events
hgs
parents:
diff changeset
   962
    // if cover UI is supported.
hgs
parents:
diff changeset
   963
    CreateAndGetSatMediatorEventProvider();
hgs
parents:
diff changeset
   964
hgs
parents:
diff changeset
   965
    TSecurityPolicy readPolicy( ECapabilityReadUserData );
hgs
parents:
diff changeset
   966
    TSecurityPolicy writePolicy( ECapabilityWriteUserData );
hgs
parents:
diff changeset
   967
hgs
parents:
diff changeset
   968
    // Define properties in P&S key for icon support
hgs
parents:
diff changeset
   969
    error = RProperty::Define( KPSUidSatServerInternal,
hgs
parents:
diff changeset
   970
        KSatAppClosedUsingEndKey, RProperty::EInt, readPolicy, writePolicy );
hgs
parents:
diff changeset
   971
        
hgs
parents:
diff changeset
   972
    LOG2( NORMAL, "CSatUiActionPerformer::ConstructL \
hgs
parents:
diff changeset
   973
        define KSatAppClosedUsingEndKey and return: %d", error )
hgs
parents:
diff changeset
   974
    
hgs
parents:
diff changeset
   975
    // Publish P&S key for icon support
hgs
parents:
diff changeset
   976
    error = RProperty::Set( KPSUidSatServerInternal, KSatAppClosedUsingEndKey,
hgs
parents:
diff changeset
   977
        KSatAppTerminatedNormal );
hgs
parents:
diff changeset
   978
    
hgs
parents:
diff changeset
   979
    LOG2( SIMPLE, "SATENGINE: CSatCommandContainer::ConstructL \
hgs
parents:
diff changeset
   980
          P&S key: %i", KSatAppTerminatedNormal )
hgs
parents:
diff changeset
   981
        
hgs
parents:
diff changeset
   982
    LOG2( NORMAL, "CSatUiActionPerformer::ConstructL \
hgs
parents:
diff changeset
   983
        publish KSatAppClosedUsingEndKey and return: %d", error )
hgs
parents:
diff changeset
   984
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::ConstructL exiting" )
hgs
parents:
diff changeset
   985
    }
hgs
parents:
diff changeset
   986
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   987
// CSatCommandContainer::CreateSatAppNameL
hgs
parents:
diff changeset
   988
// (other items were commented in a header).
hgs
parents:
diff changeset
   989
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   990
//
35
hgs
parents: 33
diff changeset
   991
void CSatCommandContainer::CreateSatAppNameL( const TDesC& aResourceId )
33
hgs
parents:
diff changeset
   992
    {
hgs
parents:
diff changeset
   993
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::CreateSatAppNameL calling" )
35
hgs
parents: 33
diff changeset
   994
    delete iSatAppName;
hgs
parents: 33
diff changeset
   995
    iSatAppName = NULL;
hgs
parents: 33
diff changeset
   996
    const TBool textResolver = HbTextResolverSymbian::Init( 
hgs
parents: 33
diff changeset
   997
        KSatServerRsc, KResourceDrive );
hgs
parents: 33
diff changeset
   998
    LOG2(NORMAL,"SATENGINE: CSatCommandContainer::\
hgs
parents: 33
diff changeset
   999
        CreateSatAppNameL textResolver = %d", textResolver ) 
hgs
parents: 33
diff changeset
  1000
    LOG2(NORMAL,"SATENGINE: CSatCommandContainer::\
hgs
parents: 33
diff changeset
  1001
        CreateSatAppNameL aResourceId = %S", &aResourceId )
33
hgs
parents:
diff changeset
  1002
35
hgs
parents: 33
diff changeset
  1003
    iSatAppName = HbTextResolverSymbian::LoadL( aResourceId );
hgs
parents: 33
diff changeset
  1004
    LOG2(NORMAL,"SATENGINE: CSatCommandContainer::\
hgs
parents: 33
diff changeset
  1005
        CreateSatAppNameL iSatAppName = %S", iSatAppName )
33
hgs
parents:
diff changeset
  1006
    iSatBipName.Copy( SatAppName() );
hgs
parents:
diff changeset
  1007
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::CreateSatAppNameL exiting" )
hgs
parents:
diff changeset
  1008
    }
hgs
parents:
diff changeset
  1009
hgs
parents:
diff changeset
  1010
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1011
// CSatCommandContainer::CreateAndGetBIPUtilsL
hgs
parents:
diff changeset
  1012
// (other items were commented in a header).
hgs
parents:
diff changeset
  1013
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1014
//
hgs
parents:
diff changeset
  1015
CSatBIPUtils* CSatCommandContainer::CreateAndGetBIPUtils()
hgs
parents:
diff changeset
  1016
    {
hgs
parents:
diff changeset
  1017
    LOG( NORMAL,
hgs
parents:
diff changeset
  1018
        "SATENGINE: CSatCommandContainer::CreateAndGetBIPUtils calling" )
hgs
parents:
diff changeset
  1019
    // If pointer is null, create new
hgs
parents:
diff changeset
  1020
    if ( !iBipUtils )
hgs
parents:
diff changeset
  1021
        {
hgs
parents:
diff changeset
  1022
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::CreateAndGetBIPUtilsL \
hgs
parents:
diff changeset
  1023
            Creating BIP Utils" )
hgs
parents:
diff changeset
  1024
        // TRAP this, We will panic, if this is NULL
hgs
parents:
diff changeset
  1025
        TInt err( KErrNone );
hgs
parents:
diff changeset
  1026
        TRAP( err, iBipUtils = CSatBIPUtils::NewL( *this ) );
hgs
parents:
diff changeset
  1027
        LOG2( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1028
                CreateAndGetBIPUtilsL BIP Utils creation status: %i", err )
hgs
parents:
diff changeset
  1029
        }
hgs
parents:
diff changeset
  1030
hgs
parents:
diff changeset
  1031
    __ASSERT_ALWAYS( iBipUtils, PanicSatEngine( ESatEngineNullPointer ) );
hgs
parents:
diff changeset
  1032
hgs
parents:
diff changeset
  1033
    LOG( NORMAL,
hgs
parents:
diff changeset
  1034
        "SATENGINE: CSatCommandContainer::CreateAndGetBIPUtils exiting" )
hgs
parents:
diff changeset
  1035
    return iBipUtils;
hgs
parents:
diff changeset
  1036
    }
hgs
parents:
diff changeset
  1037
hgs
parents:
diff changeset
  1038
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1039
// CSatCommandContainer::CreateAndGetMediatorEventProvider
hgs
parents:
diff changeset
  1040
// (other items were commented in a header).
hgs
parents:
diff changeset
  1041
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1042
//
hgs
parents:
diff changeset
  1043
CSatMediatorEventProvider* CSatCommandContainer::
hgs
parents:
diff changeset
  1044
                                        CreateAndGetSatMediatorEventProvider()
hgs
parents:
diff changeset
  1045
    {
hgs
parents:
diff changeset
  1046
    LOG( NORMAL,
hgs
parents:
diff changeset
  1047
        "SATENGINE: CSatCommandContainer::CreateAndGetSatMediatorEventProvider \
hgs
parents:
diff changeset
  1048
        calling" )
hgs
parents:
diff changeset
  1049
hgs
parents:
diff changeset
  1050
    // If pointer is null, create new
hgs
parents:
diff changeset
  1051
    if ( !iSatMediatorEvent )
hgs
parents:
diff changeset
  1052
        {
hgs
parents:
diff changeset
  1053
        LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1054
                        CreateAndGetSatMediatorEventProvider \
hgs
parents:
diff changeset
  1055
                            Creating CreateAndGetSatMediatorEventProvider" )
hgs
parents:
diff changeset
  1056
        // TRAP this, We will panic, if this is NULL
hgs
parents:
diff changeset
  1057
        TInt err( KErrNone );
hgs
parents:
diff changeset
  1058
        TRAP( err, iSatMediatorEvent = CSatMediatorEventProvider::NewL() );
hgs
parents:
diff changeset
  1059
        LOG2( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1060
            CreateAndGetCSatMediatorEventProvider status: %i", err )
hgs
parents:
diff changeset
  1061
        }
hgs
parents:
diff changeset
  1062
hgs
parents:
diff changeset
  1063
    __ASSERT_ALWAYS(
hgs
parents:
diff changeset
  1064
        iSatMediatorEvent, PanicSatEngine( ESatEngineNullPointer ) );
hgs
parents:
diff changeset
  1065
hgs
parents:
diff changeset
  1066
    LOG( NORMAL,
hgs
parents:
diff changeset
  1067
        "SATENGINE: CSatCommandContainer::CreateAndGetSatMediatorEventProvider \
hgs
parents:
diff changeset
  1068
        exiting" )
hgs
parents:
diff changeset
  1069
    return iSatMediatorEvent;
hgs
parents:
diff changeset
  1070
    }
hgs
parents:
diff changeset
  1071
hgs
parents:
diff changeset
  1072
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1073
// CSatCommandContainer::StartImportantCommandHandlersL
hgs
parents:
diff changeset
  1074
// (other items were commented in a header).
hgs
parents:
diff changeset
  1075
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1076
//
hgs
parents:
diff changeset
  1077
void CSatCommandContainer::StartImportantCommandHandlersL()
hgs
parents:
diff changeset
  1078
    {
hgs
parents:
diff changeset
  1079
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1080
        StartImportantCommandHandlersL calling" )
hgs
parents:
diff changeset
  1081
hgs
parents:
diff changeset
  1082
    // Create command handlers.
hgs
parents:
diff changeset
  1083
    RImplInfoPtrArray satCommandImplementations;
hgs
parents:
diff changeset
  1084
    CleanupStack::PushL( 
hgs
parents:
diff changeset
  1085
        TCleanupItem( CleanupPointerArray, &satCommandImplementations ) );
hgs
parents:
diff changeset
  1086
    REComSession::ListImplementationsL( KSatInterfaceDefinitionUid,
hgs
parents:
diff changeset
  1087
        satCommandImplementations );
hgs
parents:
diff changeset
  1088
    
hgs
parents:
diff changeset
  1089
    // Container for commands
hgs
parents:
diff changeset
  1090
    const TInt cmdCount( satCommandImplementations.Count() );
hgs
parents:
diff changeset
  1091
    LOG2( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1092
        StartImportantCommandHandlersL Command handler count: %d", cmdCount )
hgs
parents:
diff changeset
  1093
hgs
parents:
diff changeset
  1094
    // Check are there any command implementations
hgs
parents:
diff changeset
  1095
    if ( cmdCount > 0 )
hgs
parents:
diff changeset
  1096
        {
hgs
parents:
diff changeset
  1097
        iCmdHandlers
hgs
parents:
diff changeset
  1098
            = new ( ELeave ) CArrayPtrFlat<CSatCommandHandler>( cmdCount );
hgs
parents:
diff changeset
  1099
hgs
parents:
diff changeset
  1100
        CSatCommandHandler* setUpEventListCmd = NULL;
hgs
parents:
diff changeset
  1101
        // Add all important command handlers to list.
hgs
parents:
diff changeset
  1102
hgs
parents:
diff changeset
  1103
        // This will return KErrNotFound if the implementation is not included
hgs
parents:
diff changeset
  1104
        // in configurations
hgs
parents:
diff changeset
  1105
        TRAPD( err, setUpEventListCmd =
hgs
parents:
diff changeset
  1106
            CSatCommandHandler::NewL( KSetUpEventListUid, this ) );
hgs
parents:
diff changeset
  1107
hgs
parents:
diff changeset
  1108
        // Check does the command exist.
hgs
parents:
diff changeset
  1109
        if ( setUpEventListCmd && KErrNone == err )
hgs
parents:
diff changeset
  1110
            {
hgs
parents:
diff changeset
  1111
            LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1112
            StartImportantCommandHandlersL KErrNone == err" )
hgs
parents:
diff changeset
  1113
            setUpEventListCmd->Start();
hgs
parents:
diff changeset
  1114
            CleanupStack::PushL( setUpEventListCmd );
hgs
parents:
diff changeset
  1115
            iCmdHandlers->AppendL( setUpEventListCmd );
hgs
parents:
diff changeset
  1116
            CleanupStack::Pop( setUpEventListCmd );
hgs
parents:
diff changeset
  1117
            }
hgs
parents:
diff changeset
  1118
        }
hgs
parents:
diff changeset
  1119
    
hgs
parents:
diff changeset
  1120
    CleanupStack::PopAndDestroy( &satCommandImplementations );
hgs
parents:
diff changeset
  1121
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::\
hgs
parents:
diff changeset
  1122
        StartImportantCommandHandlersL exiting" )
hgs
parents:
diff changeset
  1123
    }
hgs
parents:
diff changeset
  1124
hgs
parents:
diff changeset
  1125
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1126
// CSatCommandContainer::CheckStartupState
hgs
parents:
diff changeset
  1127
// (other items were commented in a header).
hgs
parents:
diff changeset
  1128
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
  1129
//
hgs
parents:
diff changeset
  1130
void CSatCommandContainer::CheckStartupState( const TInt aValue )
hgs
parents:
diff changeset
  1131
    {
hgs
parents:
diff changeset
  1132
    LOG2( NORMAL, "SATENGINE: CSatCommandContainer::CheckStartupState calling\
hgs
parents:
diff changeset
  1133
        with value %d", aValue )
hgs
parents:
diff changeset
  1134
    if ( ESwStateNormalRfOn == aValue )
hgs
parents:
diff changeset
  1135
        {
hgs
parents:
diff changeset
  1136
        TRAP_IGNORE( StartCommandHandlersL() )
hgs
parents:
diff changeset
  1137
        iStartupChangeObserver->CancelNotify();
hgs
parents:
diff changeset
  1138
        // Startup phase is over
hgs
parents:
diff changeset
  1139
        iStartupPhase = EFalse;
hgs
parents:
diff changeset
  1140
        }
hgs
parents:
diff changeset
  1141
    LOG( NORMAL, "SATENGINE: CSatCommandContainer::CheckStartupState exiting" )
hgs
parents:
diff changeset
  1142
    }
hgs
parents:
diff changeset
  1143
hgs
parents:
diff changeset
  1144
// End Of File