mtpdataproviders/mtppictbridgedp/pictbridgeengine/src/dpsusbnotifier.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:
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 set mtp personality, the 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*                notification of the MTP printer connection and the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    16
*				 notification of the MTP printer disconnection. 
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
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include <e32debug.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <usbstates.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include <rptp.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
#include "dpsusbnotifier.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
#include "dpsconst.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
#include "dpsptpnotifier.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
#include "dpsconnectnotifier.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
#ifdef _DEBUG
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
#	define IF_DEBUG(t) {RDebug::t;}
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
#else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
#	define IF_DEBUG(t)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
const TInt KUnknownPersonality = 0;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
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
CDpsUsbNotifier* CDpsUsbNotifier::NewL(CDpsEngine* aEngine)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
	{
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
	IF_DEBUG(Print(_L("CDpsUsbNotifier::NewL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
	CDpsUsbNotifier* self = new(ELeave) CDpsUsbNotifier(aEngine);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
	CleanupStack::PushL(self);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
	self->ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
	CleanupStack::Pop();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
	return self;	
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
CDpsUsbNotifier::CDpsUsbNotifier(CDpsEngine* aEngine) :
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
    CActive(EPriorityNormal), iEngine(aEngine), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
    iPersonality(KUnknownPersonality), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    iConnectState(EUsbDeviceStateUndefined), iConfigured(EFalse), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
    iConnection(CDpsEngine::ENotConnected), iRollback(EFalse)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::Ctor")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    CActiveScheduler::Add(this);        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::Ctor")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
    }  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
CDpsUsbNotifier::~CDpsUsbNotifier()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
	{
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
	IF_DEBUG(Print(_L(">>>~CDpsUsbNotifier")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
	Cancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
	Rollback();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
    delete iPtpP; iPtpP = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
    delete iConnectP; iConnectP = NULL;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
    iUsbM.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    iUsbW.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
    IF_DEBUG(Print(_L("<<<~CDpsUsbNotifier")));
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
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
void CDpsUsbNotifier::ConstructL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::ConstructL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
    User::LeaveIfError(iUsbM.Connect());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
    User::LeaveIfError(iUsbW.Connect());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
    iPtpP = CDpsPtpNotifier::NewL(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
    iConnectP = CDpsConnectNotifier::NewL(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::ConstructL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
    }    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
void CDpsUsbNotifier::WaitForPrinterNotify()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
    IF_DEBUG(Print(_L("CDpsUsbNotifier::WaitForPrinterNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
    iPtpP->ChangePtpPersonality();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
//  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
void CDpsUsbNotifier::CancelPrinterNotify()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::CancelPrinterNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
    if (CDpsEngine::ENotConnected == iConnection)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
        iPtpP->Cancel(); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
        iConfigured = EFalse;    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
    else if (CDpsEngine::EPrinterConnected == iConnection)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
        iConnectP->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
    // if the request is replied through RunL before the cancel
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
    // iPrinterConnectRequest will be NULL and we don't need to cancel anything
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
    if (iEngine->PrinterConnectRequest())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
	    User::RequestComplete(iEngine->PrinterConnectRequest(), KErrCancel);   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
        }    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::CancelWaitForPrinterNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
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
void CDpsUsbNotifier::ConnectNotify()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::ConnectNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
    iConnectP->ConnectNotify();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::ConnectNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
void CDpsUsbNotifier::Rollback()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::Rollback")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
    // only when the personality has changed, we switch back to the previous
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
    // personality
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
    if (iPersonality)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
        TInt personalityId = KUsbPersonalityIdMTP;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
        iUsbM.GetCurrentPersonalityId(personalityId);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
        IF_DEBUG(Print(_L("CDpsUsbNotifier::Rollback, current personality= %d"), personalityId));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
        if(KUsbPersonalityIdPCSuiteMTP != personalityId)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
            if (!iConfigured || iRollback)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
                {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
                iUsbW.SetPreviousPersonality();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
                }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
            else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
                {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
                iUsbW.SetPreviousPersonalityOnDisconnect();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
                }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::Rollback")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
void CDpsUsbNotifier::PtpNotify(TInt aErr)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::PtpNotify %x %d"), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
        iConnectState, aErr));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
    if (aErr == KErrNone)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
        // personality changed to MTP, but cable is not connected        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
        if (iConnectState != EUsbDeviceStateUndefined)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
            if (!IsActive())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
                {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
                iEngine->Ptp().IsDpsPrinter(iStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
                SetActive();    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
                }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
        else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
            iConnection = CDpsEngine::ENotConnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
            User::RequestComplete(iEngine->PrinterConnectRequest(), iConnection);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
            }    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
        iConnection = CDpsEngine::EWrongPrintModeConnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
        User::RequestComplete(iEngine->PrinterConnectRequest(), iConnection); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
        	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::PtpNotify")));        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
//    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
void CDpsUsbNotifier::PersonalityChanged()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::PersonalityChanged %x"), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
                                                              iPersonality));     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
    if (iPersonality != KUsbPersonalityIdMTP)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
        iConnection = CDpsEngine::EWrongPrintModeConnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
        iConfigured = EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
        if (iEngine->PrinterConnectRequest())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
            User::RequestComplete(iEngine->PrinterConnectRequest(), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
                iConnection);     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
    // when UI gets this notification, it must quit. As the result, the dps 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
    // engine will be deleted so we do not need to care the further change.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::PersonalityChanged ")));     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   229
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   230
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   231
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   232
//    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   233
void CDpsUsbNotifier::RunL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   234
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   235
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::RunL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   236
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   237
    if (EPrinterAvailable == iStatus.Int())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
        iConnection = CDpsEngine::EPrinterConnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
        iConfigured = ETrue;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
        iEngine->SetDpsFolder(iEngine->Ptp().PtpFolder());			            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
    else if (iStatus.Int() != KErrCancel)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
        iConnection = CDpsEngine::EOtherConnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
    User::RequestComplete(iEngine->PrinterConnectRequest(), iConnection);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::RunL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   252
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   253
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   254
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   255
//       
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   256
void CDpsUsbNotifier::DoCancel()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::DoCancel")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
    iEngine->Ptp().CancelIsDpsPrinter();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::DoCancel")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
//       
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
TInt CDpsUsbNotifier::RunError(TInt aErr)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
    IF_DEBUG(Print(_L("CDpsUsbNotifier::RunError is %d"), aErr));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
    return aErr;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   275
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   276
//    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   277
void CDpsUsbNotifier::DisconnectNotify(TUsbDeviceState aState)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   278
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   279
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::DisconnectNotify %d"), aState));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   280
    if (iConfigured)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   281
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   282
        iConnection = CDpsEngine::EPrinterDisconnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   283
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   284
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   285
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   286
        iConnection = CDpsEngine::ENotConnected;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   287
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   288
    iConfigured = EFalse;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   289
    if (EUsbDeviceStateUndefined == aState)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   290
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   291
        iRollback = ETrue;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   292
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   293
    if (iEngine->PrinterConnectRequest())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   294
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   295
        User::RequestComplete(iEngine->PrinterConnectRequest(), iConnection);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   296
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   297
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   298
    IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::DisconnectNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   299
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   300
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   301
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   302
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   303
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   304
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   305
TInt CDpsUsbNotifier::ConnectState()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   306
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   307
    IF_DEBUG(Print(_L(">>>CDpsUsbNotifier::ConnectState")));    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   308
    TInt ret = iUsbM.GetDeviceState(iConnectState);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   309
	IF_DEBUG(Print(_L("<<<CDpsUsbNotifier::ConnectState %x"), iConnectState));    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   310
	return ret;    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   311
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   312
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   313
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   314
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   315
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   316
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   317
TBool CDpsUsbNotifier::IsSetPrintModeIssued()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   318
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   319
    return (iPersonality != KUnknownPersonality);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   320
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   321
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   322
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   323
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   324
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   325
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   326
TBool CDpsUsbNotifier::IsConfigured() const
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   327
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   328
    return iConfigured;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   329
    }