locationmapnavfw/library/src/mnservicebase.cpp
author hgs
Wed, 03 Nov 2010 23:28:39 +0530
changeset 56 4e949f03ecc5
permissions -rw-r--r--
201044
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2006 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:  CMnServiceBase class implementation
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
#include <e32base.h>
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
#include <EPos_CPosLandmark.h>
hgs
parents:
diff changeset
    22
#include <epos_poslandmarkserialization.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include "mndebug.h"
hgs
parents:
diff changeset
    25
#include "mnerrors.h"
hgs
parents:
diff changeset
    26
#include "mninternal.h"
hgs
parents:
diff changeset
    27
#include "mninternal.inl"
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
#include "mnservicebase.h"
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// ======== LOCAL FUNCTIONS ========
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// ======== MEMBER FUNCTIONS ========
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    36
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    37
//
hgs
parents:
diff changeset
    38
CMnServiceBase::CMnServiceBase()
hgs
parents:
diff changeset
    39
    {
hgs
parents:
diff changeset
    40
    iCurrentRequest = EMnIpcNone;
hgs
parents:
diff changeset
    41
    }
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    44
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    45
//
hgs
parents:
diff changeset
    46
CMnServiceBase::~CMnServiceBase()
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
    }
hgs
parents:
diff changeset
    49
hgs
parents:
diff changeset
    50
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    51
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    52
//
hgs
parents:
diff changeset
    53
void CMnServiceBase::BaseConstructL()
hgs
parents:
diff changeset
    54
    {
hgs
parents:
diff changeset
    55
    }
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    58
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    59
//
hgs
parents:
diff changeset
    60
EXPORT_C void CMnServiceBase::CompleteRequest( TInt aResult )
hgs
parents:
diff changeset
    61
    {
hgs
parents:
diff changeset
    62
    LOG1("CMnServiceBase::CompleteRequest, result %d", aResult);
hgs
parents:
diff changeset
    63
    if ( iCurrentRequest == EMnIpcNone )
hgs
parents:
diff changeset
    64
        {
hgs
parents:
diff changeset
    65
        PanicServer( KMnPanicAttemptToCompleteNoRequest );
hgs
parents:
diff changeset
    66
        }
hgs
parents:
diff changeset
    67
    else
hgs
parents:
diff changeset
    68
        {
hgs
parents:
diff changeset
    69
        Complete( iMessage, aResult );
hgs
parents:
diff changeset
    70
        iCurrentRequest = EMnIpcNone;
hgs
parents:
diff changeset
    71
        }
hgs
parents:
diff changeset
    72
    }
hgs
parents:
diff changeset
    73
hgs
parents:
diff changeset
    74
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    75
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    76
//
hgs
parents:
diff changeset
    77
void CMnServiceBase::Complete( const RMessage2& aMsg, TInt aResult )
hgs
parents:
diff changeset
    78
    {
hgs
parents:
diff changeset
    79
    //LOG1("CMnServiceBase::Complete, result %d", aResult);
hgs
parents:
diff changeset
    80
    if ( !aMsg.IsNull() )
hgs
parents:
diff changeset
    81
        {
hgs
parents:
diff changeset
    82
        aMsg.Complete( aResult );
hgs
parents:
diff changeset
    83
        }
hgs
parents:
diff changeset
    84
    }
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    87
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
    88
//
hgs
parents:
diff changeset
    89
void CMnServiceBase::HandleCancelRequestL( const RMessage2& aMessage )
hgs
parents:
diff changeset
    90
    {
hgs
parents:
diff changeset
    91
    LOG("CMnServiceBase::HandleCancelRequestL in");
hgs
parents:
diff changeset
    92
    
hgs
parents:
diff changeset
    93
    if ( IsAsyncRequestActive() && aMessage.Int0() == CurrentAsyncRequest() )
hgs
parents:
diff changeset
    94
        {
hgs
parents:
diff changeset
    95
        DoCancel();
hgs
parents:
diff changeset
    96
        CompleteRequest( KErrCancel );
hgs
parents:
diff changeset
    97
        Complete( aMessage, KErrNone );
hgs
parents:
diff changeset
    98
        }
hgs
parents:
diff changeset
    99
    else
hgs
parents:
diff changeset
   100
        {
hgs
parents:
diff changeset
   101
        LOG("CMnServiceBase::HandleCancelRequestL leave, not found");
hgs
parents:
diff changeset
   102
        User::Leave( KErrNotFound );
hgs
parents:
diff changeset
   103
        }
hgs
parents:
diff changeset
   104
        
hgs
parents:
diff changeset
   105
    LOG("CMnServiceBase::HandleCancelRequestL out");
hgs
parents:
diff changeset
   106
    }
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
// ---------------------------------------------------------
hgs
parents:
diff changeset
   109
// ---------------------------------------------------------
hgs
parents:
diff changeset
   110
//
hgs
parents:
diff changeset
   111
HBufC8* CMnServiceBase::CopyClientBuffer8LC(
hgs
parents:
diff changeset
   112
    const RMessage2& aMessage, 
hgs
parents:
diff changeset
   113
    const TInt aClientBufferParam )
hgs
parents:
diff changeset
   114
    {
hgs
parents:
diff changeset
   115
    // Create an empty server side buffer that will contain client data
hgs
parents:
diff changeset
   116
    TInt dataSize = aMessage.GetDesLengthL( aClientBufferParam );
hgs
parents:
diff changeset
   117
    HBufC8* buffer = HBufC8::NewLC( dataSize );
hgs
parents:
diff changeset
   118
hgs
parents:
diff changeset
   119
    // Populate server side buffer with client data
hgs
parents:
diff changeset
   120
    TPtr8 ptrToBuf = buffer->Des();
hgs
parents:
diff changeset
   121
    aMessage.ReadL( aClientBufferParam, ptrToBuf );
hgs
parents:
diff changeset
   122
    return buffer;
hgs
parents:
diff changeset
   123
    }
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
// ---------------------------------------------------------
hgs
parents:
diff changeset
   126
// ---------------------------------------------------------
hgs
parents:
diff changeset
   127
//
hgs
parents:
diff changeset
   128
HBufC* CMnServiceBase::CopyClientBufferLC(
hgs
parents:
diff changeset
   129
    const RMessage2& aMessage, 
hgs
parents:
diff changeset
   130
    const TInt aClientBufferParam)
hgs
parents:
diff changeset
   131
    {
hgs
parents:
diff changeset
   132
    // Create an empty server side buffer that will contain client data
hgs
parents:
diff changeset
   133
    TInt dataSize = aMessage.GetDesLengthL( aClientBufferParam );
hgs
parents:
diff changeset
   134
    HBufC* buffer = HBufC::NewLC( dataSize );
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
    // Populate server side buffer with client data
hgs
parents:
diff changeset
   137
    TPtr ptrToBuf = buffer->Des();
hgs
parents:
diff changeset
   138
    aMessage.ReadL( aClientBufferParam, ptrToBuf );
hgs
parents:
diff changeset
   139
    return buffer;
hgs
parents:
diff changeset
   140
    }
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   143
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   144
//
hgs
parents:
diff changeset
   145
CPosLandmark* CMnServiceBase::UnpackLandmarkLC( 
hgs
parents:
diff changeset
   146
    const RMessage2& aMessage,
hgs
parents:
diff changeset
   147
    TInt aParamIndex )
hgs
parents:
diff changeset
   148
    {
hgs
parents:
diff changeset
   149
    LOG("CMnServiceBase::UnpackLandmarkLC");
hgs
parents:
diff changeset
   150
    
hgs
parents:
diff changeset
   151
    HBufC8* lmBuf = CopyClientBuffer8LC( aMessage, aParamIndex );
hgs
parents:
diff changeset
   152
    
hgs
parents:
diff changeset
   153
    CPosLandmark* landmark = PosLandmarkSerialization::UnpackL( *lmBuf );
hgs
parents:
diff changeset
   154
    CleanupStack::PopAndDestroy( lmBuf );
hgs
parents:
diff changeset
   155
    CleanupStack::PushL( landmark );
hgs
parents:
diff changeset
   156
    return landmark;
hgs
parents:
diff changeset
   157
    }
hgs
parents:
diff changeset
   158
hgs
parents:
diff changeset
   159
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   160
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   161
//
hgs
parents:
diff changeset
   162
TInt CMnServiceBase::CurrentAsyncRequest()
hgs
parents:
diff changeset
   163
    {
hgs
parents:
diff changeset
   164
    return iCurrentRequest;
hgs
parents:
diff changeset
   165
    }
hgs
parents:
diff changeset
   166
    
hgs
parents:
diff changeset
   167
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   168
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   169
//
hgs
parents:
diff changeset
   170
TBool CMnServiceBase::IsAsyncRequestActive()
hgs
parents:
diff changeset
   171
    {
hgs
parents:
diff changeset
   172
    return ( iCurrentRequest != EMnIpcNone );
hgs
parents:
diff changeset
   173
    }
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   176
//  Put new request ID to stack to guarantee that if starting of asynchronous
hgs
parents:
diff changeset
   177
//  request leaves, the iCurrentRequest will be reset.
hgs
parents:
diff changeset
   178
//  If starting goes well, the PostStartAsyncRequest will pop this cleanup
hgs
parents:
diff changeset
   179
//  from stack and "current request ID" will be kept until request is competed
hgs
parents:
diff changeset
   180
//  by service implmentation.
hgs
parents:
diff changeset
   181
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   182
//
hgs
parents:
diff changeset
   183
void CMnServiceBase::PrepareAsyncRequestL( const RMessage2& aMessage )
hgs
parents:
diff changeset
   184
    {
hgs
parents:
diff changeset
   185
    LOG("CMnServiceBase::PrepareAsyncRequestL in");
hgs
parents:
diff changeset
   186
hgs
parents:
diff changeset
   187
    if ( IsAsyncRequestActive() )
hgs
parents:
diff changeset
   188
        {
hgs
parents:
diff changeset
   189
        PanicClient( aMessage, KMnPanicDuplicateRequest );
hgs
parents:
diff changeset
   190
        User::Leave( KErrInUse );
hgs
parents:
diff changeset
   191
        }
hgs
parents:
diff changeset
   192
hgs
parents:
diff changeset
   193
    iMessage = aMessage;
hgs
parents:
diff changeset
   194
    iCurrentRequest = aMessage.Function();
hgs
parents:
diff changeset
   195
hgs
parents:
diff changeset
   196
    LOG("CMnServiceBase::PrepareAsyncRequestL out");
hgs
parents:
diff changeset
   197
    }
hgs
parents:
diff changeset
   198
hgs
parents:
diff changeset
   199
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   200
//  From class CApaAppServiceBase
hgs
parents:
diff changeset
   201
// ---------------------------------------------------------------------------
hgs
parents:
diff changeset
   202
//
hgs
parents:
diff changeset
   203
EXPORT_C void CMnServiceBase::ServiceError( const RMessage2 &aMessage, TInt aError )
hgs
parents:
diff changeset
   204
    {
hgs
parents:
diff changeset
   205
    LOG2("CMnServiceBase::ServiceError function %d, error %d",
hgs
parents:
diff changeset
   206
        aMessage.Function(), aError );
hgs
parents:
diff changeset
   207
    
hgs
parents:
diff changeset
   208
    if ( IsAsyncRequestActive() && 
hgs
parents:
diff changeset
   209
         aMessage.Handle() == iMessage.Handle() )
hgs
parents:
diff changeset
   210
        {
hgs
parents:
diff changeset
   211
        // starting this async request failed, rollback
hgs
parents:
diff changeset
   212
        LOG1("CMnServiceBase::ServiceError forgetting async request %d", iCurrentRequest );
hgs
parents:
diff changeset
   213
        iCurrentRequest = EMnIpcNone;
hgs
parents:
diff changeset
   214
        }
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
    CAknAppServiceBase::ServiceError( aMessage, aError );
hgs
parents:
diff changeset
   217
    LOG("CMnServiceBase::ServiceError out");
hgs
parents:
diff changeset
   218
    }