mtpdataproviders/mtppictbridgedp/pictbridgeengine/src/dpsconnectnotifier.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:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2006, 2007 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  This class implements functions of the notification of the 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*                PTP printer connction and disconnection. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    16
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    17
*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    18
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#include "dpsconnectnotifier.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include "dpsusbnotifier.h"
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    22
#include "OstTraceDefinitions.h"
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    23
#ifdef OST_TRACE_COMPILER_IN_USE
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    24
#include "dpsconnectnotifierTraces.h"
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
const TUint KUsbAllStates = 0xFFFFFFFF;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
CDpsConnectNotifier* CDpsConnectNotifier::NewL(CDpsUsbNotifier* aParent)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
    CDpsConnectNotifier* self = new(ELeave) CDpsConnectNotifier(aParent);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
    return self;	    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
//     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
CDpsConnectNotifier::CDpsConnectNotifier(CDpsUsbNotifier* aParent) :
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
    CActive(EPriorityNormal), iNotifier(aParent) 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    46
    OstTraceFunctionEntry0( DUP1_CDPSCONNECTNOTIFIER_CDPSCONNECTNOTIFIER_CONS_ENTRY ); 
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
    CActiveScheduler::Add(this);
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    48
    OstTraceFunctionExit0( DUP1_CDPSCONNECTNOTIFIER_CDPSCONNECTNOTIFIER_CONS_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
//     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
CDpsConnectNotifier::~CDpsConnectNotifier()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    57
    OstTraceFunctionEntry0( CDPSCONNECTNOTIFIER_CDPSCONNECTNOTIFIER_DES_ENTRY );  
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    Cancel();
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    59
    OstTraceFunctionExit0( CDPSCONNECTNOTIFIER_CDPSCONNECTNOTIFIER_DES_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
//     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
void CDpsConnectNotifier::ConnectNotify()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    68
    OstTraceFunctionEntry0( CDPSCONNECTNOTIFIER_CONNECTNOTIFY_ENTRY );  
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    if (!IsActive())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
	    iNotifier->iUsbM.DeviceStateNotification(KUsbAllStates, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
	                                             iNotifier->iConnectState, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
	                                             iStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
        SetActive();			
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    75
        } 	
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    76
    OstTraceFunctionExit0( CDPSCONNECTNOTIFIER_CONNECTNOTIFY_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
void CDpsConnectNotifier::RunL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    85
    OstTraceFunctionEntry0( CDPSCONNECTNOTIFIER_RUNL_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    86
    OstTrace1( TRACE_NORMAL, CDPSCONNECTNOTIFIER_RUNL, "status %d", iNotifier->iConnectState );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    87
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
    if (KErrNone == iStatus.Int())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
        // notify connect (by set personality)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
        if (iNotifier->iConnectState == EUsbDeviceStateConfigured && 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
            !iNotifier->iConfigured)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
            iNotifier->PtpNotify(KErrNone);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
        // Notify disconnect on cable disconnection and for compatible printer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
        // also when other device state than configured or suspended is entered. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
        else if (  (iNotifier->iConnectState == EUsbDeviceStateUndefined) ||
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
                ( iNotifier->IsConfigured() && 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
                        (iNotifier->iConnectState != EUsbDeviceStateConfigured) &&
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
                        (iNotifier->iConnectState != EUsbDeviceStateSuspended) )  )
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
            iNotifier->DisconnectNotify(iNotifier->iConnectState);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
            } 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
        else // not the state we are interested, keep on listening
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
            iNotifier->iUsbM.DeviceStateNotification(KUsbAllStates, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
	                                                 iNotifier->iConnectState, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
	                                                 iStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
            SetActive();	                                             
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
        {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   117
        OstTrace0( TRACE_WARNING, DUP1_CDPSCONNECTNOTIFIER_RUNL, "the iStatus is wrong!!!" );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   118
        }      
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   119
    OstTraceFunctionExit0( CDPSCONNECTNOTIFIER_RUNL_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
void CDpsConnectNotifier::DoCancel()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   128
    OstTraceFunctionEntry0( CDPSCONNECTNOTIFIER_DOCANCEL_ENTRY );  
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
    iNotifier->iUsbM.DeviceStateNotificationCancel();
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   130
    OstTraceFunctionExit0( CDPSCONNECTNOTIFIER_DOCANCEL_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
// 
60
841f70763fbe 201044_04
hgs
parents: 49
diff changeset
   137
#ifdef OST_TRACE_COMPILER_IN_USE
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
TInt CDpsConnectNotifier::RunError(TInt aErr)
60
841f70763fbe 201044_04
hgs
parents: 49
diff changeset
   139
#else
841f70763fbe 201044_04
hgs
parents: 49
diff changeset
   140
TInt CDpsConnectNotifier::RunError(TInt /*aErr*/)
841f70763fbe 201044_04
hgs
parents: 49
diff changeset
   141
#endif
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   143
    OstTraceDef1(OST_TRACE_CATEGORY_PRODUCTION, TRACE_IMPORTANT, CDPSCONNECTNOTIFIER_RUNERROR, 
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   144
            "CDpsConnectNotifier::RunError is %d", aErr );
60
841f70763fbe 201044_04
hgs
parents: 49
diff changeset
   145
    return KErrNone;
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
    }