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