mtptransports/mtpcontroller/src/cmtpoperator.cpp
author hgs
Fri, 23 Jul 2010 18:35:35 +0800
changeset 35 c4c427c00f31
parent 29 3ae5cb0b4c02
child 47 63cf70d3ecd8
permissions -rw-r--r--
201029_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"
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    24
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    25
__FLOG_STMT( _LIT8( KComponent, "mtpoperator" ); )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    26
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    27
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    28
CMTPOperator* CMTPOperator::NewL( MMTPOperatorNotifier& aNotifier )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    29
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    30
    CMTPOperator* self = new( ELeave ) CMTPOperator( aNotifier );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    31
    self->ConstructL();
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    32
    return self;
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    33
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    34
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    35
CMTPOperator::~CMTPOperator()
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
    Cancel();
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    38
    iPendingOperations.Reset();
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    39
    iPendingOperations.Close();
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    40
    iMTPClient.Close();
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    41
    iProperty.Close();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    42
    delete iTimer;
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    43
    __FLOG( _L8("+/-Dtor") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    44
    __FLOG_CLOSE;
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    45
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    46
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    47
void CMTPOperator::StartTransport( TUid aTransport )
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
    __FLOG_1( _L8("+/-StartTransport( 0x%08X )"), aTransport.iUid );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    50
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    51
    TInt err = AppendOperation( EStartTransport, aTransport );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    52
    if ( KErrNone != err )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    53
        {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    54
        iNotifier.HandleStartTrasnportCompleteL( 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
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    57
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    58
void CMTPOperator::StopTransport( TUid aTransport )
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
    __FLOG_1( _L8("+/-StopTransport( 0x%08X )"), aTransport.iUid );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    61
    TInt err = AppendOperation( EStopTransport, aTransport );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    62
    if ( KErrNone != err )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    63
        {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    64
        iNotifier.HandleStartTrasnportCompleteL( err );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    65
        }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    66
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    67
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    68
void CMTPOperator::StartTimer(TInt aSecond)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    69
    {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    70
    __FLOG(_L8("StartTimer in cmtpoperator!"));
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    71
    iTimer->Start(aSecond);    
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    72
    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    73
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    74
void CMTPOperator::DoCancel()
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    75
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    76
    __FLOG( _L8("+/-DoCancel") );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    77
    iProperty.Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    78
    iConSubscribed = EFalse;
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    79
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    80
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    81
void CMTPOperator::RunL()
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    82
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    83
    __FLOG( _L8("+RunL") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    84
    
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    85
    iConSubscribed = EFalse;
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    86
    TInt count = iPendingOperations.Count();
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    87
    
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    88
    TInt connState = KInitialValue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    89
    
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    90
    if ( count > 0 )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    91
        {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    92
        TOperation& operation = iPendingOperations[0];
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    93
        TRAP_IGNORE( HandleOperationL( operation ) );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    94
        iPendingOperations.Remove( 0 );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
    95
        }
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    96
    else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    97
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    98
        //this will go on to get the updated connection status.
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
    99
        SubscribeConnState();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   100
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   101
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   102
        TInt error = iProperty.Get(KMTPPublishConnStateCat, EMTPConnStateKey, connState);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   103
        __FLOG_2(_L8("Before, the iConnState is %d and connState is %d"), iConnState, connState);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   104
        if ( KErrNotFound == error )
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   105
            {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   106
            iConnState = KInitialValue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   107
            __FLOG( _L8("The key is deleted and mtp server shut down!") );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   108
            }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   109
        else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   110
            {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   111
            if (iTimer->IsActive() && !iTimer->GetStopTransportStatus())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   112
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   113
                __FLOG( _L8("Timer is cancelled!") );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   114
                iTimer->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   115
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   116
            //if the disconnect is not set, set the disconnect
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   117
            //else if the connState is disconnect, launch the timer to restart the server to unload dps.
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   118
            if ( KInitialValue == iConnState )
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   119
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   120
                iConnState = connState;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   121
                __FLOG( _L8("the first time to launch mtp") );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   122
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   123
            else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   124
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   125
                if (EDisconnectedFromHost == connState)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   126
                    {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   127
                    iConnState = connState;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   128
                    if (!iTimer->IsActive())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   129
                        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   130
                        iTimer->Start(KStopMTPSeconds);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   131
                        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   132
                    __FLOG( _L8("Timer is launched.") );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   133
                    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   134
                else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   135
                    {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   136
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   137
                    iConnState = connState;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   138
                    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   139
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   140
            }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   141
        __FLOG_2(_L8("After, the iConnState is %d and connState is %d"), iConnState, connState);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   142
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   143
       
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   144
    __FLOG( _L8("-RunL") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   145
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   146
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   147
CMTPOperator::CMTPOperator( MMTPOperatorNotifier& aNotifier ):
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   148
    CActive( EPriorityStandard ),
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   149
    iNotifier( aNotifier )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   150
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   151
    __FLOG_OPEN( KMTPSubsystem, KComponent );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   152
    __FLOG( _L8("+/-Ctor") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   153
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   154
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   155
void CMTPOperator::ConstructL()
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   156
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   157
    __FLOG( _L8("+ConstructL") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   158
    CActiveScheduler::Add( this );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   159
    //if the server is running, the first disconnction shows the conection is down!
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   160
    if(KErrNone == iMTPClient.IsProcessRunning())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   161
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   162
        iConnState = EDisconnectedFromHost;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   163
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   164
    else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   165
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   166
        iConnState = KInitialValue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   167
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   168
    __FLOG_1( _L8("The connstate is set to %d"), iConnState );
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   169
    User::LeaveIfError( iMTPClient.Connect() );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   170
    User::LeaveIfError(iProperty.Attach(KMTPPublishConnStateCat, EMTPConnStateKey));
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   171
    iTimer = CMTPControllerTimer::NewL(iMTPClient, *this);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   172
    
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   173
    iConSubscribed = EFalse;
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   174
    __FLOG( _L8("-ConstructL") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   175
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   176
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   177
TInt CMTPOperator::AppendOperation( TOperationType aType, TUid aTransport )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   178
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   179
    TOperation operation = { aType, aTransport };
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   180
    TInt err = iPendingOperations.Append( operation );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   181
    __FLOG_1( _L8("+AppendOperation returns %d"), err );
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   182
    if ( ( KErrNone == err ) && !IsActive() )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   183
        {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   184
        Schedule( KErrNone );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   185
        }
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   186
    else
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   187
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   188
        if (iConSubscribed)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   189
            {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   190
            Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   191
            if (KErrNone == err)
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   192
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   193
                Schedule( KErrNone );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   194
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   195
            }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   196
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   197
    __FLOG( _L8("-AppendOperation") );
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   198
    return err;
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   199
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   200
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   201
void CMTPOperator::Schedule( TInt aError )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   202
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   203
    __FLOG_1( _L8("+/-Schedule( %d )"), aError );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   204
    if(iTimer->IsActive())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   205
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   206
        iTimer->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   207
        }
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   208
    TRequestStatus* status = &iStatus;
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   209
    User::RequestComplete( status, aError );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   210
    SetActive();
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::HandleOperationL( const TOperation& aOperation )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   214
    {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   215
    __FLOG_2( _L8("+HandleOperationL( 0x%08X, 0x%08X )"), aOperation.iTransport.iUid, aOperation.iType );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   216
    TInt err = KErrNone;
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   217
    switch ( aOperation.iType )
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   218
        {
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   219
        case EStartTransport:
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   220
            err = iMTPClient.StartTransport( aOperation.iTransport );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   221
            iNotifier.HandleStartTrasnportCompleteL( err );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   222
            SubscribeConnState();
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   223
            break;
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   224
        default:
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   225
            __ASSERT_DEBUG( ( EStopTransport == aOperation.iType ), User::Invariant() );
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   226
            if(!iTimer->GetStopTransportStatus())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   227
                {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   228
                err = iMTPClient.StopTransport( aOperation.iTransport );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   229
                }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   230
         
0
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   231
            iNotifier.HandleStopTrasnportCompleteL( err );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   232
            break;
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
    __FLOG( _L8("-HandleOperationL") );
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   235
    }
d0791faffa3f Revision: 201003
Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
parents:
diff changeset
   236
29
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   237
void CMTPOperator::SubscribeConnState()
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   238
    {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   239
    if(!IsActive())
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   240
        {
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   241
        __FLOG( _L8("Subscribe connection state changed)") );
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   242
        iProperty.Subscribe(iStatus);
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   243
        iConSubscribed = ETrue;
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   244
        SetActive();
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   245
        }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   246
  
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   247
    }
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   248
3ae5cb0b4c02 201025_07
hgs
parents: 0
diff changeset
   249