author | hgs |
Thu, 04 Nov 2010 15:31:42 +0800 | |
changeset 60 | 841f70763fbe |
parent 49 | c20dd21d1eb4 |
permissions | -rw-r--r-- |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
1 |
// Copyright (c) 2007-2009 Nokia Corporation and/or its subsidiary(-ies). |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
2 |
// All rights reserved. |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
3 |
// This component and the accompanying materials are made available |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
4 |
// under the terms of "Eclipse Public License v1.0" |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
5 |
// which accompanies this distribution, and is available |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
6 |
// at the URL "http://www.eclipse.org/legal/epl-v10.html". |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
7 |
// |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
8 |
// Initial Contributors: |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
9 |
// Nokia Corporation - initial contribution. |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
10 |
// |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
11 |
// Contributors: |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
12 |
// |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
13 |
// Description: |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
14 |
// |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
15 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
16 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
17 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
18 |
/** |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
19 |
@file |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
20 |
@internalComponent |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
21 |
*/ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
22 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
23 |
#include "cmtpoperator.h" |
49 | 24 |
#include "mtpdebug.h" |
25 |
#include "OstTraceDefinitions.h" |
|
26 |
#ifdef OST_TRACE_COMPILER_IN_USE |
|
27 |
#include "cmtpoperatorTraces.h" |
|
28 |
#endif |
|
29 | 29 |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
30 |
CMTPOperator* CMTPOperator::NewL( MMTPOperatorNotifier& aNotifier ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
31 |
{ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
32 |
CMTPOperator* self = new( ELeave ) CMTPOperator( aNotifier ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
33 |
self->ConstructL(); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
34 |
return self; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
35 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
36 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
37 |
CMTPOperator::~CMTPOperator() |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
38 |
{ |
49 | 39 |
OstTraceFunctionEntry0( CMTPOPERATOR_DES_ENTRY ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
40 |
Cancel(); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
41 |
iPendingOperations.Reset(); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
42 |
iPendingOperations.Close(); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
43 |
iMTPClient.Close(); |
29 | 44 |
iProperty.Close(); |
45 |
delete iTimer; |
|
49 | 46 |
OstTraceFunctionExit0( CMTPOPERATOR_DES_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
47 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
48 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
49 |
void CMTPOperator::StartTransport( TUid aTransport ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
50 |
{ |
49 | 51 |
OstTraceFunctionEntry0( CMTPOPERATOR_STARTTRANSPORT_ENTRY ); |
52 |
OstTrace1( TRACE_NORMAL, CMTPOPERATOR_STARTTRANSPORT, "The transport uid is 0x%08X", aTransport.iUid ); |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
53 |
TInt err = AppendOperation( EStartTransport, aTransport ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
54 |
if ( KErrNone != err ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
55 |
{ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
56 |
iNotifier.HandleStartTrasnportCompleteL( err ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
57 |
} |
49 | 58 |
OstTraceFunctionExit0( CMTPOPERATOR_STARTTRANSPORT_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
59 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
60 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
61 |
void CMTPOperator::StopTransport( TUid aTransport ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
62 |
{ |
49 | 63 |
OstTraceFunctionEntry0( CMTPOPERATOR_STOPTRANSPORT_ENTRY ); |
64 |
OstTrace1( TRACE_NORMAL, CMTPOPERATOR_STOPTRANSPORT, "The transport uid is 0x%08X", aTransport.iUid ); |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
65 |
TInt err = AppendOperation( EStopTransport, aTransport ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
66 |
if ( KErrNone != err ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
67 |
{ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
68 |
iNotifier.HandleStartTrasnportCompleteL( err ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
69 |
} |
49 | 70 |
OstTraceFunctionExit0( CMTPOPERATOR_STOPTRANSPORT_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
71 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
72 |
|
29 | 73 |
void CMTPOperator::StartTimer(TInt aSecond) |
74 |
{ |
|
49 | 75 |
OstTraceFunctionEntry0( CMTPOPERATOR_STARTTIMER_ENTRY ); |
29 | 76 |
iTimer->Start(aSecond); |
49 | 77 |
OstTraceFunctionExit0( CMTPOPERATOR_STARTTIMER_EXIT ); |
29 | 78 |
} |
79 |
||
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
80 |
void CMTPOperator::DoCancel() |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
81 |
{ |
49 | 82 |
OstTraceFunctionEntry0( CMTPOPERATOR_DOCANCEL_ENTRY ); |
29 | 83 |
iProperty.Cancel(); |
84 |
iConSubscribed = EFalse; |
|
49 | 85 |
OstTraceFunctionExit0( CMTPOPERATOR_DOCANCEL_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
86 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
87 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
88 |
void CMTPOperator::RunL() |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
89 |
{ |
49 | 90 |
OstTraceFunctionEntry0( CMTPOPERATOR_RUNL_ENTRY ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
91 |
|
29 | 92 |
iConSubscribed = EFalse; |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
93 |
TInt count = iPendingOperations.Count(); |
29 | 94 |
|
95 |
TInt connState = KInitialValue; |
|
96 |
||
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
97 |
if ( count > 0 ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
98 |
{ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
99 |
TOperation& operation = iPendingOperations[0]; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
100 |
TRAP_IGNORE( HandleOperationL( operation ) ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
101 |
iPendingOperations.Remove( 0 ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
102 |
} |
29 | 103 |
else |
104 |
{ |
|
105 |
//this will go on to get the updated connection status. |
|
106 |
SubscribeConnState(); |
|
107 |
||
108 |
||
109 |
TInt error = iProperty.Get(KMTPPublishConnStateCat, EMTPConnStateKey, connState); |
|
49 | 110 |
OstTraceExt2( TRACE_NORMAL, CMTPOPERATOR_RUNL, "Before, the iConnState is %d and connState is %d", iConnState, connState ); |
29 | 111 |
if ( KErrNotFound == error ) |
112 |
{ |
|
113 |
iConnState = KInitialValue; |
|
49 | 114 |
OstTrace0( TRACE_NORMAL, DUP1_CMTPOPERATOR_RUNL, "The key is deleted and mtp server shut down!" ); |
29 | 115 |
} |
116 |
else |
|
117 |
{ |
|
118 |
if (iTimer->IsActive() && !iTimer->GetStopTransportStatus()) |
|
119 |
{ |
|
49 | 120 |
OstTrace0( TRACE_NORMAL, DUP2_CMTPOPERATOR_RUNL, "Timer is cancelled!" ); |
29 | 121 |
iTimer->Cancel(); |
122 |
} |
|
123 |
//if the disconnect is not set, set the disconnect |
|
124 |
//else if the connState is disconnect, launch the timer to restart the server to unload dps. |
|
125 |
if ( KInitialValue == iConnState ) |
|
126 |
{ |
|
127 |
iConnState = connState; |
|
49 | 128 |
OstTrace0( TRACE_NORMAL, DUP3_CMTPOPERATOR_RUNL, "the first time to launch mtp" ); |
29 | 129 |
} |
130 |
else |
|
131 |
{ |
|
132 |
if (EDisconnectedFromHost == connState) |
|
133 |
{ |
|
134 |
iConnState = connState; |
|
135 |
if (!iTimer->IsActive()) |
|
136 |
{ |
|
137 |
iTimer->Start(KStopMTPSeconds); |
|
138 |
} |
|
49 | 139 |
OstTrace0( TRACE_NORMAL, DUP4_CMTPOPERATOR_RUNL, "Timer is launched." ); |
29 | 140 |
} |
141 |
else |
|
142 |
{ |
|
143 |
||
144 |
iConnState = connState; |
|
145 |
} |
|
146 |
} |
|
147 |
} |
|
49 | 148 |
OstTraceExt2( TRACE_NORMAL, DUP5_CMTPOPERATOR_RUNL, "After, the iConnState is %d and connState is %d", iConnState, connState ); |
29 | 149 |
} |
49 | 150 |
OstTraceFunctionExit0( CMTPOPERATOR_RUNL_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
151 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
152 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
153 |
CMTPOperator::CMTPOperator( MMTPOperatorNotifier& aNotifier ): |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
154 |
CActive( EPriorityStandard ), |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
155 |
iNotifier( aNotifier ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
156 |
{ |
49 | 157 |
OstTraceFunctionEntry0( CMTPOPERATOR_CONS_ENTRY ); |
158 |
OstTraceFunctionExit0( CMTPOPERATOR_CONS_EXIT ); |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
159 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
160 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
161 |
void CMTPOperator::ConstructL() |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
162 |
{ |
49 | 163 |
OstTraceFunctionEntry0( CMTPOPERATOR_CONSTRUCTL_ENTRY ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
164 |
CActiveScheduler::Add( this ); |
29 | 165 |
//if the server is running, the first disconnction shows the conection is down! |
166 |
if(KErrNone == iMTPClient.IsProcessRunning()) |
|
167 |
{ |
|
168 |
iConnState = EDisconnectedFromHost; |
|
169 |
} |
|
170 |
else |
|
171 |
{ |
|
172 |
iConnState = KInitialValue; |
|
173 |
} |
|
49 | 174 |
OstTrace1( TRACE_NORMAL, CMTPOPERATOR_CONSTRUCTL, "The connstate is set to %d", iConnState ); |
175 |
||
176 |
LEAVEIFERROR( iMTPClient.Connect(), |
|
177 |
OstTrace0( TRACE_ERROR, DUP1_CMTPOPERATOR_CONSTRUCTL, "Leave when the client connects to mtp server" )); |
|
178 |
||
179 |
LEAVEIFERROR(iProperty.Attach(KMTPPublishConnStateCat, EMTPConnStateKey), |
|
180 |
OstTrace0( TRACE_ERROR, DUP2_CMTPOPERATOR_CONSTRUCTL, "iProperty attached failed." )); |
|
29 | 181 |
iTimer = CMTPControllerTimer::NewL(iMTPClient, *this); |
182 |
||
183 |
iConSubscribed = EFalse; |
|
49 | 184 |
OstTraceFunctionExit0( CMTPOPERATOR_CONSTRUCTL_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
185 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
186 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
187 |
TInt CMTPOperator::AppendOperation( TOperationType aType, TUid aTransport ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
188 |
{ |
49 | 189 |
OstTraceFunctionEntry0( CMTPOPERATOR_APPENDOPERATION_ENTRY ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
190 |
TOperation operation = { aType, aTransport }; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
191 |
TInt err = iPendingOperations.Append( operation ); |
49 | 192 |
OstTrace1( TRACE_NORMAL, CMTPOPERATOR_APPENDOPERATION, "The return value is %d", err ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
193 |
if ( ( KErrNone == err ) && !IsActive() ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
194 |
{ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
195 |
Schedule( KErrNone ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
196 |
} |
29 | 197 |
else |
198 |
{ |
|
199 |
if (iConSubscribed) |
|
200 |
{ |
|
201 |
Cancel(); |
|
202 |
if (KErrNone == err) |
|
203 |
{ |
|
204 |
Schedule( KErrNone ); |
|
205 |
} |
|
206 |
} |
|
207 |
} |
|
49 | 208 |
|
209 |
OstTraceFunctionExit0( CMTPOPERATOR_APPENDOPERATION_EXIT ); |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
210 |
return err; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
211 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
212 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
213 |
void CMTPOperator::Schedule( TInt aError ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
214 |
{ |
49 | 215 |
OstTraceFunctionEntry0( CMTPOPERATOR_SCHEDULE_ENTRY ); |
216 |
OstTrace1( TRACE_NORMAL, CMTPOPERATOR_SCHEDULE, "The error value is %d", aError ); |
|
29 | 217 |
if(iTimer->IsActive()) |
218 |
{ |
|
219 |
iTimer->Cancel(); |
|
220 |
} |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
221 |
TRequestStatus* status = &iStatus; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
222 |
User::RequestComplete( status, aError ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
223 |
SetActive(); |
49 | 224 |
OstTraceFunctionExit0( CMTPOPERATOR_SCHEDULE_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
225 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
226 |
|
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
227 |
void CMTPOperator::HandleOperationL( const TOperation& aOperation ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
228 |
{ |
49 | 229 |
OstTraceFunctionEntry0( CMTPOPERATOR_HANDLEOPERATIONL_ENTRY ); |
230 |
OstTraceExt2( TRACE_NORMAL, CMTPOPERATOR_HANDLEOPERATIONL, "The transport id is 0x%08X and the operation is 0x%08X", (TInt)aOperation.iTransport.iUid, aOperation.iType ); |
|
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
231 |
TInt err = KErrNone; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
232 |
switch ( aOperation.iType ) |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
233 |
{ |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
234 |
case EStartTransport: |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
235 |
err = iMTPClient.StartTransport( aOperation.iTransport ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
236 |
iNotifier.HandleStartTrasnportCompleteL( err ); |
29 | 237 |
SubscribeConnState(); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
238 |
break; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
239 |
default: |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
240 |
__ASSERT_DEBUG( ( EStopTransport == aOperation.iType ), User::Invariant() ); |
29 | 241 |
if(!iTimer->GetStopTransportStatus()) |
242 |
{ |
|
243 |
err = iMTPClient.StopTransport( aOperation.iTransport ); |
|
244 |
} |
|
245 |
||
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
246 |
iNotifier.HandleStopTrasnportCompleteL( err ); |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
247 |
break; |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
248 |
} |
49 | 249 |
OstTraceFunctionExit0( CMTPOPERATOR_HANDLEOPERATIONL_EXIT ); |
0
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
250 |
} |
d0791faffa3f
Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff
changeset
|
251 |
|
29 | 252 |
void CMTPOperator::SubscribeConnState() |
253 |
{ |
|
49 | 254 |
OstTraceFunctionEntry0( CMTPOPERATOR_SUBSCRIBECONNSTATE_ENTRY ); |
29 | 255 |
if(!IsActive()) |
256 |
{ |
|
257 |
iProperty.Subscribe(iStatus); |
|
258 |
iConSubscribed = ETrue; |
|
259 |
SetActive(); |
|
260 |
} |
|
261 |
||
49 | 262 |
OstTraceFunctionExit0( CMTPOPERATOR_SUBSCRIBECONNSTATE_EXIT ); |
29 | 263 |
} |
264 |
||
265 |