bluetoothengine/headsetsimulator/core/src/Server/hsclient.cpp
author michal.sulewski
Wed, 15 Sep 2010 15:59:44 +0200
branchheadsetsimulator
changeset 60 90dbfc0435e3
permissions -rw-r--r--
source code commit
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
60
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     1
/*
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     2
 * Component Name: Headset Simulator
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     3
 * Author: Comarch S.A.
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     4
 * Version: 1.0
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     5
 * Copyright (c) 2010 Comarch S.A.
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     6
 *  
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     7
 * This Software is submitted by Comarch S.A. to Symbian Foundation Limited on 
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     8
 * the basis of the Member Contribution Agreement entered between Comarch S.A. 
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
     9
 * and Symbian Foundation Limited on 5th June 2009 (“Agreement”) and may be 
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    10
 * used only in accordance with the terms and conditions of the Agreement. 
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    11
 * Any other usage, duplication or redistribution of this Software is not 
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    12
 * allowed without written permission of Comarch S.A.
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    13
 * 
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    14
 */
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    15
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    16
#include "hsclient.h"
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    17
#include "hsclientobservers.h"
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    18
#include "debug.h"
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    19
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    20
CHsClient* CHsClient::NewL( CBluetoothSocket *aClient,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    21
        MHsClientStateNotifier *aClientStateNotifier,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    22
        MHsClientObserver *aClientDisconnectNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    23
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    24
    User::LeaveIfNull( aClient );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    25
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    26
    CHsClient *self = CHsClient::NewLC( aClient, aClientStateNotifier,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    27
            aClientDisconnectNotifier );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    28
    CleanupStack::Pop( self );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    29
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    30
    return self;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    31
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    32
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    33
CHsClient* CHsClient::NewLC( CBluetoothSocket *aClient,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    34
        MHsClientStateNotifier *aClientStateNotifier,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    35
        MHsClientObserver *aClientDisconnectNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    36
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    37
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    38
    User::LeaveIfNull( aClient );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    39
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    40
    CHsClient *self = new ( ELeave ) CHsClient( *aClient, aClientStateNotifier,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    41
            aClientDisconnectNotifier );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    42
    CleanupStack::PushL( self );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    43
    self->ConstructL();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    44
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    45
    return self;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    46
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    47
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    48
CHsClient::~CHsClient()
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    49
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    50
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    51
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    52
    if ( iSocket )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    53
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    54
        iSocket->CancelAll();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    55
        delete iSocket;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    56
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    57
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    58
    if ( iConnected )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    59
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    60
        if ( iStateNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    61
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    62
            TRAP_IGNORE( iStateNotifier->HandleClientDisconnectL(KErrNone) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    63
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    64
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    65
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    66
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    67
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    68
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    69
void CHsClient::Send( const TDesC8 &aData )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    70
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    71
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    72
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    73
    if ( iSocket && iConnected )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    74
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    75
        TRAP_IGNORE( BufferedProcessL(aData) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    76
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    77
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    78
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    79
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    80
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    81
void CHsClient::SetClientDisconnectNotfier( MHsClientObserver &aNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    82
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    83
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    84
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    85
    iClientObserver = &aNotifier;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    86
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    87
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    88
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    89
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    90
void CHsClient::SetClientStateNotfier( MHsClientStateNotifier &aNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    91
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    92
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    93
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    94
    iStateNotifier = &aNotifier;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    95
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    96
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    97
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    98
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
    99
MHsClientStateNotifier* CHsClient::GetClientStateNotifer()
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   100
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   101
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   102
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   103
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   104
    return iStateNotifier;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   105
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   106
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   107
CHsClient::CHsClient( CBluetoothSocket &aClient,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   108
        MHsClientStateNotifier *aClientStateNotifier,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   109
        MHsClientObserver *aClientDisconnectNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   110
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   111
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   112
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   113
    iSocket = &aClient;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   114
    iStateNotifier = aClientStateNotifier;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   115
    iState = CHsClient::EIdle;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   116
    iConnected = ETrue;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   117
    iClientObserver = aClientDisconnectNotifier;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   118
    iSocket->SetNotifier( *this );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   119
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   120
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   121
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   122
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   123
void CHsClient::ConstructL()
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   124
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   125
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   126
    BufferedProcessL();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   127
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   128
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   129
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   130
void CHsClient::RawRecvL( TDes8 &aData )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   131
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   132
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   133
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   134
    User::LeaveIfNull( iSocket );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   135
    if ( !iConnected )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   136
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   137
        TRACE_INFO( _L(" Client is no longer connected" ) )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   138
        User::LeaveIfError( KErrDisconnected );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   139
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   140
    iState = CHsClient::EReceiving;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   141
    User::LeaveIfError( iSocket->RecvOneOrMore( aData, iReceiveFlag,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   142
            iReceiveMessageLength ) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   143
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   144
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   145
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   146
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   147
void CHsClient::RawSendL( const TDesC8 &aData )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   148
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   149
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   150
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   151
    User::LeaveIfNull( iSocket );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   152
    if ( !iConnected )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   153
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   154
        User::LeaveIfError( KErrDisconnected );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   155
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   156
    if ( aData.Length() == 0 )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   157
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   158
        User::Leave( KErrWrite );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   159
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   160
    iState = CHsClient::ESending;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   161
    User::LeaveIfError( iSocket->Send( aData, iSendFlag ) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   162
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   163
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   164
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   165
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   166
void CHsClient::BufferedProcessL( const TDesC8 &aData )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   167
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   168
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   169
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   170
    if ( iState != CHsClient::ESending )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   171
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   172
        iTempSendBuf.Append( aData );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   173
        SwapBuffers();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   174
        if ( iSendBuf.Length() > 0 )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   175
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   176
            iSocket->CancelRecv();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   177
            RawSendL( iSendBuf );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   178
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   179
        else if ( iState != CHsClient::ESending )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   180
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   181
            RawRecvL( iReceiveMessageBuffer );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   182
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   183
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   184
    else
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   185
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   186
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   187
        iTempSendBuf.Append( aData );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   188
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   189
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   190
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   191
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   192
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   193
void CHsClient::SwapBuffers()
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   194
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   195
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   196
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   197
    iSendBuf.Copy( iTempSendBuf );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   198
    iTempSendBuf.Zero();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   199
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   200
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   201
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   202
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   203
void CHsClient::HandleConnectCompleteL( TInt aErr )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   204
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   205
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   206
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   207
    TRACE_INFO( ( _L("aErr = %d"), aErr) )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   208
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   209
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   210
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   211
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   212
void CHsClient::HandleAcceptCompleteL( TInt aErr )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   213
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   214
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   215
    TRACE_INFO( ( _L("aErr = %d"), aErr) )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   216
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   217
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   218
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   219
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   220
void CHsClient::HandleShutdownCompleteL( TInt aErr )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   221
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   222
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   223
    TRACE_INFO( ( _L("aErr = %d"), aErr) )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   224
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   225
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   226
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   227
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   228
void CHsClient::HandleSendCompleteL( TInt aErr )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   229
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   230
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   231
    TRACE_INFO( ( _L("aErr = %d"), aErr) )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   232
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   233
    iState = CHsClient::EIdle;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   234
    iSendBuf.Zero();
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   235
    if ( aErr != KErrDisconnected )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   236
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   237
        BufferedProcessL( KNullDesC8 );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   238
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   239
    if ( iStateNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   240
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   241
        if ( aErr != KErrDisconnected )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   242
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   243
            iStateNotifier->HandleClientSendCompleteL( aErr );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   244
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   245
        else
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   246
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   247
            iConnected = EFalse;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   248
            iStateNotifier->HandleClientDisconnectL( aErr );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   249
            iClientObserver->HandleClientDisconnect( this, aErr );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   250
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   251
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   252
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   253
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   254
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   255
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   256
void CHsClient::HandleReceiveCompleteL( TInt aErr )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   257
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   258
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   259
    TRACE_INFO( ( _L("aErr = %d"), aErr) )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   260
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   261
    iState = CHsClient::EIdle;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   262
    if ( iStateNotifier )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   263
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   264
        if ( aErr == KErrNone )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   265
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   266
            TRAP_IGNORE( iStateNotifier->HandleClientReceiveCompleteL(
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   267
                            iReceiveMessageBuffer, aErr ) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   268
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   269
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   270
        else
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   271
            {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   272
            iConnected = EFalse;
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   273
            iStateNotifier->HandleClientDisconnectL( aErr );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   274
            iClientObserver->HandleClientDisconnect( this, aErr );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   275
            }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   276
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   277
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   278
    if ( aErr == KErrNone )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   279
        {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   280
        BufferedProcessL( KNullDesC8 );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   281
        }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   282
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   283
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   284
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   285
void CHsClient::HandleIoctlCompleteL( TInt aErr )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   286
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   287
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   288
    TRACE_INFO( ( _L("aErr = %d"), aErr) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   289
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   290
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   291
    }
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   292
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   293
void CHsClient::HandleActivateBasebandEventNotifierCompleteL( TInt aErr,
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   294
        TBTBasebandEventNotification& aEventNotification )
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   295
    {
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   296
    TRACE_FUNC_ENTRY
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   297
    TRACE_INFO( ( _L("aErr = %d"), aErr) );
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   298
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   299
    TRACE_FUNC_EXIT
90dbfc0435e3 source code commit
michal.sulewski
parents:
diff changeset
   300
    }