mtptransports/mtpcontroller/src/cmtpoperator.cpp
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 49 c20dd21d1eb4
permissions -rw-r--r--
201044_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    24
#include "mtpdebug.h"
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    25
#include "OstTraceDefinitions.h"
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    26
#ifdef OST_TRACE_COMPILER_IN_USE
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    27
#include "cmtpoperatorTraces.h"
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    28
#endif
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    44
    iProperty.Close();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    45
    delete iTimer;
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    51
    OstTraceFunctionEntry0( CMTPOPERATOR_STARTTRANSPORT_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    63
    OstTraceFunctionEntry0( CMTPOPERATOR_STOPTRANSPORT_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    73
void CMTPOperator::StartTimer(TInt aSecond)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    74
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    75
    OstTraceFunctionEntry0( CMTPOPERATOR_STARTTIMER_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    76
    iTimer->Start(aSecond);    
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    77
    OstTraceFunctionExit0( CMTPOPERATOR_STARTTIMER_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    78
    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    82
    OstTraceFunctionEntry0( CMTPOPERATOR_DOCANCEL_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    83
    iProperty.Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    84
    iConSubscribed = EFalse;
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    90
    OstTraceFunctionEntry0( CMTPOPERATOR_RUNL_ENTRY );
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    91
    
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    94
    
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    95
    TInt connState = KInitialValue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   103
    else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   104
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   105
        //this will go on to get the updated connection status.
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   106
        SubscribeConnState();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   107
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   108
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   109
        TInt error = iProperty.Get(KMTPPublishConnStateCat, EMTPConnStateKey, connState);
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   110
        OstTraceExt2( TRACE_NORMAL, CMTPOPERATOR_RUNL, "Before, the iConnState is %d and connState is %d", iConnState, connState );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   111
        if ( KErrNotFound == error )
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   112
            {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   113
            iConnState = KInitialValue;
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   114
            OstTrace0( TRACE_NORMAL, DUP1_CMTPOPERATOR_RUNL, "The key is deleted and mtp server shut down!" );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   115
            }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   116
        else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   117
            {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   118
            if (iTimer->IsActive() && !iTimer->GetStopTransportStatus())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   119
                {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   120
                OstTrace0( TRACE_NORMAL, DUP2_CMTPOPERATOR_RUNL, "Timer is cancelled!" );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   121
                iTimer->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   122
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   123
            //if the disconnect is not set, set the disconnect
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   124
            //else if the connState is disconnect, launch the timer to restart the server to unload dps.
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   125
            if ( KInitialValue == iConnState )
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   126
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   127
                iConnState = connState;
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   128
                OstTrace0( TRACE_NORMAL, DUP3_CMTPOPERATOR_RUNL, "the first time to launch mtp" );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   129
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   130
            else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   131
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   132
                if (EDisconnectedFromHost == connState)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   133
                    {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   134
                    iConnState = connState;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   135
                    if (!iTimer->IsActive())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   136
                        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   137
                        iTimer->Start(KStopMTPSeconds);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   138
                        }
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   139
                    OstTrace0( TRACE_NORMAL, DUP4_CMTPOPERATOR_RUNL, "Timer is launched." );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   140
                    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   141
                else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   142
                    {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   143
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   144
                    iConnState = connState;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   145
                    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   146
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   147
            }
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   148
        OstTraceExt2( TRACE_NORMAL, DUP5_CMTPOPERATOR_RUNL, "After, the iConnState is %d and connState is %d", iConnState, connState );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   149
        }
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   157
    OstTraceFunctionEntry0( CMTPOPERATOR_CONS_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   165
    //if the server is running, the first disconnction shows the conection is down!
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   166
    if(KErrNone == iMTPClient.IsProcessRunning())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   167
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   168
        iConnState = EDisconnectedFromHost;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   169
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   170
    else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   171
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   172
        iConnState = KInitialValue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   173
        }
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   174
    OstTrace1( TRACE_NORMAL, CMTPOPERATOR_CONSTRUCTL, "The connstate is set to %d", iConnState );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   175
    
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   176
    LEAVEIFERROR( iMTPClient.Connect(),
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   177
            OstTrace0( TRACE_ERROR, DUP1_CMTPOPERATOR_CONSTRUCTL, "Leave when the client connects to mtp server" ));
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   178
    
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   179
    LEAVEIFERROR(iProperty.Attach(KMTPPublishConnStateCat, EMTPConnStateKey),
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   180
            OstTrace0( TRACE_ERROR, DUP2_CMTPOPERATOR_CONSTRUCTL, "iProperty attached failed." ));
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   181
    iTimer = CMTPControllerTimer::NewL(iMTPClient, *this);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   182
    
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   183
    iConSubscribed = EFalse;
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   197
    else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   198
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   199
        if (iConSubscribed)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   200
            {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   201
            Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   202
            if (KErrNone == err)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   203
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   204
                Schedule( KErrNone );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   205
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   206
            }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   207
        }
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   208
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   215
    OstTraceFunctionEntry0( CMTPOPERATOR_SCHEDULE_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   216
    OstTrace1( TRACE_NORMAL, CMTPOPERATOR_SCHEDULE, "The error value is %d", aError );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   217
    if(iTimer->IsActive())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   218
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   219
        iTimer->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   229
    OstTraceFunctionEntry0( CMTPOPERATOR_HANDLEOPERATIONL_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   241
            if(!iTimer->GetStopTransportStatus())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   242
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   243
                err = iMTPClient.StopTransport( aOperation.iTransport );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   244
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   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
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   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
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   252
void CMTPOperator::SubscribeConnState()
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   253
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   254
    OstTraceFunctionEntry0( CMTPOPERATOR_SUBSCRIBECONNSTATE_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   255
    if(!IsActive())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   256
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   257
        iProperty.Subscribe(iStatus);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   258
        iConSubscribed = ETrue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   259
        SetActive();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   260
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   261
  
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   262
    OstTraceFunctionExit0( CMTPOPERATOR_SUBSCRIBECONNSTATE_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   263
    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   264
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   265