satengine/satserver/SatInternalClient/src/CSatCPlayToneHandler.cpp
author hgs
Fri, 03 Sep 2010 13:59:20 +0300
changeset 46 2fa1fa551b0b
parent 33 8d5d7fcf9b59
permissions -rw-r--r--
201035
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
33
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002-2008 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:  This is the handler for the SIM Application Toolkit
hgs
parents:
diff changeset
    15
*                Play Tone proactive command.
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    <e32svr.h>
hgs
parents:
diff changeset
    21
#include    "RSatUiSession.h"
hgs
parents:
diff changeset
    22
#include    "MSatUiObserver.h"
hgs
parents:
diff changeset
    23
#include    "SatSOpcodes.h"
hgs
parents:
diff changeset
    24
#include    "CSatCPlayToneHandler.h"
hgs
parents:
diff changeset
    25
#include    "SatLog.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
// Used when Play tone doesn't contain duration.
hgs
parents:
diff changeset
    28
const TInt KSatPtDefaultDuration = 5;
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
// ======== MEMBER FUNCTIONS ========
hgs
parents:
diff changeset
    31
hgs
parents:
diff changeset
    32
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    33
// CSatCPlayToneHandler::CSatCPlayToneHandler
hgs
parents:
diff changeset
    34
// C++ default constructor can NOT contain any code, that
hgs
parents:
diff changeset
    35
// might leave.
hgs
parents:
diff changeset
    36
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    37
//
hgs
parents:
diff changeset
    38
CSatCPlayToneHandler::CSatCPlayToneHandler(
hgs
parents:
diff changeset
    39
    TInt aPriority,
hgs
parents:
diff changeset
    40
    RSatUiSession* aSession ) :
hgs
parents:
diff changeset
    41
    CActive( aPriority ),
hgs
parents:
diff changeset
    42
    iSession( aSession ),
hgs
parents:
diff changeset
    43
    iPlayToneData(),
hgs
parents:
diff changeset
    44
    iPlayTonePckg( iPlayToneData ),
hgs
parents:
diff changeset
    45
    iPlayToneRsp(),
hgs
parents:
diff changeset
    46
    iPlayToneRspPckg( iPlayToneRsp )
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
    LOG( SIMPLE,
hgs
parents:
diff changeset
    49
        "SATINTERNALCLIENT: CSatCPlayToneHandler::CSatCPlayToneHandler calling" )
hgs
parents:
diff changeset
    50
hgs
parents:
diff changeset
    51
    // Add to active scheduler.
hgs
parents:
diff changeset
    52
    CActiveScheduler::Add( this );
hgs
parents:
diff changeset
    53
hgs
parents:
diff changeset
    54
    LOG( SIMPLE,
hgs
parents:
diff changeset
    55
        "SATINTERNALCLIENT: CSatCPlayToneHandler::CSatCPlayToneHandler exiting" )
hgs
parents:
diff changeset
    56
    }
hgs
parents:
diff changeset
    57
hgs
parents:
diff changeset
    58
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    59
// CSatCPlayToneHandler::NewL
hgs
parents:
diff changeset
    60
// Two-phased constructor.
hgs
parents:
diff changeset
    61
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    62
//
hgs
parents:
diff changeset
    63
CSatCPlayToneHandler* CSatCPlayToneHandler::NewL(
hgs
parents:
diff changeset
    64
    RSatUiSession* aSat )
hgs
parents:
diff changeset
    65
    {
hgs
parents:
diff changeset
    66
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::NewL calling" )
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
    // Perform the construction.
hgs
parents:
diff changeset
    69
    CSatCPlayToneHandler* self =
hgs
parents:
diff changeset
    70
        new ( ELeave ) CSatCPlayToneHandler( EPriorityLow, aSat );
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::NewL exiting" )
hgs
parents:
diff changeset
    73
    return self;
hgs
parents:
diff changeset
    74
    }
hgs
parents:
diff changeset
    75
hgs
parents:
diff changeset
    76
// Destructor
hgs
parents:
diff changeset
    77
CSatCPlayToneHandler::~CSatCPlayToneHandler()
hgs
parents:
diff changeset
    78
    {
hgs
parents:
diff changeset
    79
    LOG( SIMPLE,
hgs
parents:
diff changeset
    80
        "SATINTERNALCLIENT: CSatCPlayToneHandler::~CSatCPlayToneHandler calling" )
hgs
parents:
diff changeset
    81
    // Cancel any outstanding requests.
hgs
parents:
diff changeset
    82
hgs
parents:
diff changeset
    83
    Cancel();
hgs
parents:
diff changeset
    84
    iSession = NULL;
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
    LOG( SIMPLE,
hgs
parents:
diff changeset
    87
        "SATINTERNALCLIENT: CSatCPlayToneHandler::~CSatCPlayToneHandler exiting" )
hgs
parents:
diff changeset
    88
    }
hgs
parents:
diff changeset
    89
hgs
parents:
diff changeset
    90
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    91
// CSatCPlayToneHandler::Start
hgs
parents:
diff changeset
    92
// Starts the handler.
hgs
parents:
diff changeset
    93
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    94
//
hgs
parents:
diff changeset
    95
void CSatCPlayToneHandler::Start()
hgs
parents:
diff changeset
    96
    {
hgs
parents:
diff changeset
    97
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::Start calling" )
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
    // Empty the IPC data
hgs
parents:
diff changeset
   100
    RSat::TPlayToneV2 temp;
hgs
parents:
diff changeset
   101
    iPlayToneData = temp;
hgs
parents:
diff changeset
   102
    RSat::TPlayToneRspV1 temp2;
hgs
parents:
diff changeset
   103
    iPlayToneRsp = temp2;
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
    // Request Play Tone notification.
hgs
parents:
diff changeset
   106
    TIpcArgs arguments( &iPlayTonePckg );
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
    // Pass the Play Tone IPC package.
hgs
parents:
diff changeset
   109
    iSession->CreateRequest( ESatSProactivePlayTone, arguments, iStatus );
hgs
parents:
diff changeset
   110
hgs
parents:
diff changeset
   111
    // Set this handler to active so that it can receive requests.
hgs
parents:
diff changeset
   112
    SetActive();
hgs
parents:
diff changeset
   113
hgs
parents:
diff changeset
   114
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::Start exiting" )
hgs
parents:
diff changeset
   115
    }
hgs
parents:
diff changeset
   116
hgs
parents:
diff changeset
   117
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   118
// CSatCPlayToneHandler::RunL
hgs
parents:
diff changeset
   119
// Handles the command.
hgs
parents:
diff changeset
   120
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   121
//
hgs
parents:
diff changeset
   122
void CSatCPlayToneHandler::RunL()
hgs
parents:
diff changeset
   123
    {
hgs
parents:
diff changeset
   124
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::RunL calling" )
hgs
parents:
diff changeset
   125
hgs
parents:
diff changeset
   126
    // Check the status of the asnychronous operation
hgs
parents:
diff changeset
   127
    if ( KErrNone != iStatus.Int() )
hgs
parents:
diff changeset
   128
        {
hgs
parents:
diff changeset
   129
        LOG2(
hgs
parents:
diff changeset
   130
            SIMPLE,
hgs
parents:
diff changeset
   131
            "SATINTERNALCLIENT: CSatCPlayToneHandler::RunL exiting, error: %d",
hgs
parents:
diff changeset
   132
            iStatus.Int() )
hgs
parents:
diff changeset
   133
hgs
parents:
diff changeset
   134
        // Renew the request
hgs
parents:
diff changeset
   135
        Start();
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
        return;
hgs
parents:
diff changeset
   138
        }
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
    // Determine the play duration.
hgs
parents:
diff changeset
   141
    TTimeIntervalMicroSeconds interval( static_cast<TInt64>( 0 ) );
hgs
parents:
diff changeset
   142
    LOG2( SIMPLE,
hgs
parents:
diff changeset
   143
    "SATINTERNALCLIENT: CSatCPlayToneHandler::RunL \
hgs
parents:
diff changeset
   144
    iPlayToneData.iDuration.iTimeUnit: %d",iPlayToneData.iDuration.iTimeUnit )
hgs
parents:
diff changeset
   145
    switch ( iPlayToneData.iDuration.iTimeUnit )
hgs
parents:
diff changeset
   146
        {
hgs
parents:
diff changeset
   147
        case RSat::EMinutes:
hgs
parents:
diff changeset
   148
            {
hgs
parents:
diff changeset
   149
            TInt64 temp1(
hgs
parents:
diff changeset
   150
            static_cast<TInt>( iPlayToneData.iDuration.iNumOfUnits ) );
hgs
parents:
diff changeset
   151
            TInt64 temp2( KSatCMicroSecondsInMinute );
hgs
parents:
diff changeset
   152
            interval = temp1 * temp2;
hgs
parents:
diff changeset
   153
            break;
hgs
parents:
diff changeset
   154
            }
hgs
parents:
diff changeset
   155
        case RSat::ESeconds:
hgs
parents:
diff changeset
   156
            {
hgs
parents:
diff changeset
   157
            interval = iPlayToneData.iDuration.iNumOfUnits *
hgs
parents:
diff changeset
   158
                KSatCMicroSecondsInSecond;
hgs
parents:
diff changeset
   159
            break;
hgs
parents:
diff changeset
   160
            }
hgs
parents:
diff changeset
   161
        case RSat::ETenthsOfSeconds:
hgs
parents:
diff changeset
   162
            {
hgs
parents:
diff changeset
   163
            interval = iPlayToneData.iDuration.iNumOfUnits *
hgs
parents:
diff changeset
   164
                KSatCMicroSecondsInOneTenthSecond;
hgs
parents:
diff changeset
   165
            break;
hgs
parents:
diff changeset
   166
            }
hgs
parents:
diff changeset
   167
        case RSat::ETimeUnitNotSet:
hgs
parents:
diff changeset
   168
        case RSat::ENoDurationAvailable:
hgs
parents:
diff changeset
   169
            {
hgs
parents:
diff changeset
   170
            // We are defaulting to 5 seconds in S60
hgs
parents:
diff changeset
   171
            interval = KSatPtDefaultDuration *
hgs
parents:
diff changeset
   172
                KSatCMicroSecondsInSecond;
hgs
parents:
diff changeset
   173
            break;
hgs
parents:
diff changeset
   174
            }
hgs
parents:
diff changeset
   175
        default:
hgs
parents:
diff changeset
   176
            {
hgs
parents:
diff changeset
   177
            LOG( SIMPLE, "SATINTERNALCLIENT: Unexpected time unit" )
hgs
parents:
diff changeset
   178
            }
hgs
parents:
diff changeset
   179
        }
hgs
parents:
diff changeset
   180
    // Set the type of tone to be played.
hgs
parents:
diff changeset
   181
    // Cannot use static_cast directly because of GCC
hgs
parents:
diff changeset
   182
    TSatTone dialTone( static_cast<TSatTone>(
hgs
parents:
diff changeset
   183
        static_cast<TInt>( iPlayToneData.iTone ) ) );
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
    // Has to be casted to TInt before casting to TSatIconQualifier, because
hgs
parents:
diff changeset
   186
    // GCC warns about the direct cast.
hgs
parents:
diff changeset
   187
    const struct TSatIconId iconId = { iPlayToneData.iIconId.iIdentifier,
hgs
parents:
diff changeset
   188
        static_cast<TSatIconQualifier>(
hgs
parents:
diff changeset
   189
            static_cast<TInt>( iPlayToneData.iIconId.iQualifier ) ) };
hgs
parents:
diff changeset
   190
hgs
parents:
diff changeset
   191
    // This will contain EFalse if requested icon is not displayed.
hgs
parents:
diff changeset
   192
    // And if icon is displayed, it contains ETrue.
hgs
parents:
diff changeset
   193
    TBool requestedIconDisplayed( EFalse );
hgs
parents:
diff changeset
   194
hgs
parents:
diff changeset
   195
    // Notify the registered client and save the response.
hgs
parents:
diff changeset
   196
    TSatUiResponse response = iSession->SatUiObserver()->PlayTone(
hgs
parents:
diff changeset
   197
        iPlayToneData.iAlphaId.iAlphaId, dialTone, interval,
hgs
parents:
diff changeset
   198
        iconId, requestedIconDisplayed );
hgs
parents:
diff changeset
   199
hgs
parents:
diff changeset
   200
    // This command never has any additional information.
hgs
parents:
diff changeset
   201
    iPlayToneRsp.iInfoType = RSat::KNoAdditionalInfo;
hgs
parents:
diff changeset
   202
    iPlayToneRsp.iAdditionalInfo.Zero();
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
    iPlayToneRsp.SetPCmdNumber( iPlayToneData.PCmdNumber() );
hgs
parents:
diff changeset
   205
hgs
parents:
diff changeset
   206
    // Examine the client response.
hgs
parents:
diff changeset
   207
    ExamineClientResponse(
hgs
parents:
diff changeset
   208
        response, requestedIconDisplayed );
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
    // Pass the Play Tone response IPC package.
hgs
parents:
diff changeset
   211
    TIpcArgs arguments( &iPlayToneRspPckg );
hgs
parents:
diff changeset
   212
hgs
parents:
diff changeset
   213
    // Perform the IPC data transfer.
hgs
parents:
diff changeset
   214
    iSession->CreateRequest( ESatSProactivePlayToneResponse, arguments );
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
    // Renew the request
hgs
parents:
diff changeset
   217
    Start();
hgs
parents:
diff changeset
   218
hgs
parents:
diff changeset
   219
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::RunL exiting" )
hgs
parents:
diff changeset
   220
    }
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   223
// CSatCPlayToneHandler::ExamineClientResponse
hgs
parents:
diff changeset
   224
// Examine the client response.
hgs
parents:
diff changeset
   225
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   226
//
hgs
parents:
diff changeset
   227
void CSatCPlayToneHandler::ExamineClientResponse(
hgs
parents:
diff changeset
   228
    TSatUiResponse aResponse,
hgs
parents:
diff changeset
   229
    TBool aRequestedIconDisplayed )
hgs
parents:
diff changeset
   230
    {
hgs
parents:
diff changeset
   231
    LOG2( SIMPLE,
hgs
parents:
diff changeset
   232
    "SATINTERNALCLIENT: CSatCPlayToneHandler::ExamineClientResponse calling,\
hgs
parents:
diff changeset
   233
    aResponse: %x", aResponse )
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
    // Examine the client response.
hgs
parents:
diff changeset
   236
    switch ( aResponse )
hgs
parents:
diff changeset
   237
        {
hgs
parents:
diff changeset
   238
        case ESatSuccess:
hgs
parents:
diff changeset
   239
        case ESatSuccessToneNotPlayed: // for future use,
hgs
parents:
diff changeset
   240
        // specified in ETSI spec but not currently implemented in etelsat.
hgs
parents:
diff changeset
   241
            {
hgs
parents:
diff changeset
   242
            // Convert terminal rsp if icon used
hgs
parents:
diff changeset
   243
            RSat::TPCmdResult result( RSat::KSuccess );
hgs
parents:
diff changeset
   244
            RSat::TIconQualifier iconQualifier(
hgs
parents:
diff changeset
   245
                iPlayToneData.iIconId.iQualifier );
hgs
parents:
diff changeset
   246
hgs
parents:
diff changeset
   247
            if ( !aRequestedIconDisplayed )
hgs
parents:
diff changeset
   248
                {
hgs
parents:
diff changeset
   249
                LOG( SIMPLE,
hgs
parents:
diff changeset
   250
                "SATINTERNALCLIENT: CSatCPlayToneHandler::ExamineClientResponse \
hgs
parents:
diff changeset
   251
                aRequestedIconDisplayed false" )
hgs
parents:
diff changeset
   252
                if ( iconQualifier == RSat::ESelfExplanatory ||
hgs
parents:
diff changeset
   253
                     iconQualifier == RSat::ENotSelfExplanatory )
hgs
parents:
diff changeset
   254
                    {
hgs
parents:
diff changeset
   255
                    LOG( SIMPLE,
hgs
parents:
diff changeset
   256
                    "SATINTERNALCLIENT: CSatCPlayToneHandler::ExamineClientResponse \
hgs
parents:
diff changeset
   257
                    IconNotDisplayed" )
hgs
parents:
diff changeset
   258
                    result = RSat::KSuccessRequestedIconNotDisplayed;
hgs
parents:
diff changeset
   259
                    }
hgs
parents:
diff changeset
   260
                }
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
            iPlayToneRsp.iGeneralResult = result;
hgs
parents:
diff changeset
   263
            break;
hgs
parents:
diff changeset
   264
            }
hgs
parents:
diff changeset
   265
        case ESatFailure:
hgs
parents:
diff changeset
   266
            {
hgs
parents:
diff changeset
   267
            iPlayToneRsp.iInfoType = RSat::KMeProblem;
hgs
parents:
diff changeset
   268
            iPlayToneRsp.iGeneralResult = RSat::KMeUnableToProcessCmd;
hgs
parents:
diff changeset
   269
            iPlayToneRsp.iAdditionalInfo.SetLength( 1 );
hgs
parents:
diff changeset
   270
            iPlayToneRsp.iAdditionalInfo[0] = RSat::KNoSpecificMeProblem;
hgs
parents:
diff changeset
   271
            break;
hgs
parents:
diff changeset
   272
            }
hgs
parents:
diff changeset
   273
        case ESatSessionTerminatedByUser:
hgs
parents:
diff changeset
   274
            {
hgs
parents:
diff changeset
   275
            iPlayToneRsp.iGeneralResult = RSat::KPSessionTerminatedByUser;
hgs
parents:
diff changeset
   276
            break;
hgs
parents:
diff changeset
   277
            }
hgs
parents:
diff changeset
   278
        case ESatBackwardModeRequestedByUser:
hgs
parents:
diff changeset
   279
            {
hgs
parents:
diff changeset
   280
            iPlayToneRsp.iGeneralResult =
hgs
parents:
diff changeset
   281
                RSat::KBackwardModeRequestedByUser;
hgs
parents:
diff changeset
   282
            break;
hgs
parents:
diff changeset
   283
            }
hgs
parents:
diff changeset
   284
        case ESatNoResponseFromUser:
hgs
parents:
diff changeset
   285
            {
hgs
parents:
diff changeset
   286
            iPlayToneRsp.iGeneralResult = RSat::KNoResponseFromUser;
hgs
parents:
diff changeset
   287
            break;
hgs
parents:
diff changeset
   288
            }
hgs
parents:
diff changeset
   289
        case ESatCmdDataNotUnderstood:
hgs
parents:
diff changeset
   290
            {
hgs
parents:
diff changeset
   291
            iPlayToneRsp.iGeneralResult = RSat::KCmdDataNotUnderstood;
hgs
parents:
diff changeset
   292
            iPlayToneRsp.iInfoType = RSat::KNoAdditionalInfo;
hgs
parents:
diff changeset
   293
            iPlayToneRsp.iAdditionalInfo.Zero();
hgs
parents:
diff changeset
   294
            break;
hgs
parents:
diff changeset
   295
            }
hgs
parents:
diff changeset
   296
        // No help is ever available with this command.
hgs
parents:
diff changeset
   297
        case EHelpRequestedByUser:
hgs
parents:
diff changeset
   298
        case EPCmdNotAcceptedByUser:
hgs
parents:
diff changeset
   299
        default:
hgs
parents:
diff changeset
   300
            {
hgs
parents:
diff changeset
   301
            iSession->Panic( ESatInvalidResponse );
hgs
parents:
diff changeset
   302
            break;
hgs
parents:
diff changeset
   303
            }
hgs
parents:
diff changeset
   304
        }
hgs
parents:
diff changeset
   305
hgs
parents:
diff changeset
   306
    LOG( SIMPLE,
hgs
parents:
diff changeset
   307
        "SATINTERNALCLIENT: CSatCPlayToneHandler::ExamineClientResponse exiting" )
hgs
parents:
diff changeset
   308
    }
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   311
// CSatCPlayToneHandler::DoCancel
hgs
parents:
diff changeset
   312
// Cancels the pending request.
hgs
parents:
diff changeset
   313
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   314
//
hgs
parents:
diff changeset
   315
void CSatCPlayToneHandler::DoCancel()
hgs
parents:
diff changeset
   316
    {
hgs
parents:
diff changeset
   317
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::DoCancel calling" )
hgs
parents:
diff changeset
   318
hgs
parents:
diff changeset
   319
    // Complete the request with cancel code.
hgs
parents:
diff changeset
   320
    TRequestStatus* requestStatus = &iStatus;
hgs
parents:
diff changeset
   321
    User::RequestComplete( requestStatus, KErrCancel );
hgs
parents:
diff changeset
   322
hgs
parents:
diff changeset
   323
    LOG( SIMPLE, "SATINTERNALCLIENT: CSatCPlayToneHandler::DoCancel exiting" )
hgs
parents:
diff changeset
   324
    }