mtpdataproviders/mtppictbridgedp/pictbridgeengine/src/pictbridge.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 defines and implements the API for UI engine. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    15
*
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
#include <e32base.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#include <e32debug.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include <dps.rsg>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <f32file.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include <barsc.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
#include <barsread.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
#include <bautils.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
#include <pathinfo.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
#include "pictbridge.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
#include "dpsdefs.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
#include "dpsxmlstring.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
#include "dpsconst.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
#include "dpsstatemachine.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
#include "dpsscriptreceiver.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
#include "dpsusbnotifier.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
#include "dpsparam.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
#include "dpsscriptsender.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
#include "dpstransaction.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
#include "dpsfile.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
#ifdef _DEBUG
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
#	define IF_DEBUG(t) {RDebug::t;}
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
#else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
#	define IF_DEBUG(t)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
const TInt KResource = 32;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
const TInt KDriver = 3;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
// ---------------------------------------------------------------------------
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
EXPORT_C CDpsEngine* CDpsEngine::GetEngineL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
    IF_DEBUG(Print(_L("CDpsEngine::GetEngineL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
    CDpsEngine* me;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
    me = static_cast<CDpsEngine*>(Dll::Tls());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
    if (!me)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
        CDpsEngine* self = new(ELeave) CDpsEngine();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
        CleanupStack::PushL(self);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
        self->ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
        CleanupStack::Pop();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
        User::LeaveIfError(Dll::SetTls(self));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
        return self;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
        return me;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
        }			    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
EXPORT_C void CDpsEngine::Delete()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
    IF_DEBUG(Print(_L(">>>DpsEngine::Delete")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
    CDpsEngine *me; me = static_cast<CDpsEngine*>(Dll::Tls());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
    if (me)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
        delete me;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
        Dll::SetTls(NULL);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    IF_DEBUG(Print(_L("<<<DpsEngine::Delete")));	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
void CDpsEngine::ConstructL()	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
    IF_DEBUG(Print(_L(">>>CDpsEngine::ConstructL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
    iDpsParameters = TDpsXmlString::NewL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
    User::LeaveIfError(iPtp.Connect());    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
    iDpsOperator = CDpsStateMachine::NewL(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
    iUsbNotifier = CDpsUsbNotifier::NewL(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
    IF_DEBUG(Print(_L("<<<DpsEngine::ConstructL")));		
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
// ---------------------------------------------------------------------------
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
CDpsEngine::~CDpsEngine()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
	{
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
    IF_DEBUG(Print(_L(">>>~CDpsEngine")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
    delete iDpsOperator;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    iDpsOperator = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
    delete iUsbNotifier;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
    iUsbNotifier = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
		
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
    if (iDpsOperationRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
        User::RequestComplete(iDpsOperationRequest, KErrCancel);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
    if (iDpsEventRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
        User::RequestComplete(iDpsEventRequest, KErrCancel);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
        }    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
    if (iPrinterConnectRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
        User::RequestComplete(iPrinterConnectRequest, KErrCancel);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
        }	    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
    delete iDpsParameters;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
    iDpsParameters = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
    iPtp.Close();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
    IF_DEBUG(Print(_L("<<<~CDpsEngine")));
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
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
EXPORT_C void CDpsEngine::SetPrintMode(TRequestStatus& aStatus)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
    IF_DEBUG(Print(_L(">>>DpsEngine::SearchPrinter")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    iPrinterConnectRequest = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
    *iPrinterConnectRequest = KRequestPending;		
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
    iUsbNotifier->WaitForPrinterNotify();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
    IF_DEBUG(Print(_L("<<<DpsEngine::SearchPrinter")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
	}
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
EXPORT_C void CDpsEngine::CancelPrintMode()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
    IF_DEBUG(Print(_L(">>>DpsEngine::CancelSearchPrinter")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
    iUsbNotifier->CancelPrinterNotify();				
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
    IF_DEBUG(Print(_L("<<<DpsEngine::CancelSearchPrinter")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
EXPORT_C void CDpsEngine::ConnectStateNotify(TRequestStatus& aStatus)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
    IF_DEBUG(Print(_L(">>>DpsEngine::ConnectStateNotifyL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
    // SetPrintMode must be finished
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
    if (!iUsbNotifier->IsSetPrintModeIssued())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
        TRequestStatus* status = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
        User::RequestComplete(status, KErrNotReady);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
    iPrinterConnectRequest = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    *iPrinterConnectRequest = KRequestPending;		
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
    iUsbNotifier->ConnectNotify();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
    IF_DEBUG(Print(_L("<<<DpsEngine::ConnecStatetNotifyL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
EXPORT_C void CDpsEngine::DoDpsRequestL(TMDpsOperation* aRequest, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
                                       TRequestStatus& aStatus)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
    IF_DEBUG(Print(_L(">>>DpsEngine::DoDpsRequestL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
    // the ptp printer must be connected and registered for the dps event
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
    if (!iUsbNotifier->IsConfigured() || !iDpsEventRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
        TRequestStatus* status = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
        User::RequestComplete(status, KErrNotReady);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
    // there is a request from the host received and the reply has been
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
    // sending out, but the host has not received it yet. we can not send
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
    // the device request now
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
    IF_DEBUG(Print(_L("curState is %x, idleState is %x"), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
        iDpsOperator->CurState(), iDpsOperator->IdleState()));    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
    if (iDpsOperator->CurState() != iDpsOperator->IdleState())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
        TRequestStatus* status = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
        User::RequestComplete(status, KErrInUse);        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
    iDpsOperator->StartTransactionL(aRequest);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
    iDpsOperationRequest = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
    *iDpsOperationRequest = KRequestPending;    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
    IF_DEBUG(Print(_L("<<<DpsEngine::DoDpsRequestL")));           
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
	}
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
EXPORT_C void CDpsEngine::CancelDpsRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
    IF_DEBUG(Print(_L(">>>DpsEngine::CancelDpsOperation")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
    if (iDpsOperationRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
        iDpsOperator->ScriptSender()->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
        User::RequestComplete(iDpsOperationRequest, KErrCancel);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
    iDpsOperator->Initialize();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
    IF_DEBUG(Print(_L("<<<DpsEngine::CancelDpsOperation")));
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
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   234
//   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   235
EXPORT_C void CDpsEngine::DpsEventNotify(TDpsEvents& aParam,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   236
                                         TRequestStatus& aStatus)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   237
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
    IF_DEBUG(Print(_L(">>>DpsEngine::DpsEventNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
    // the PTP printer must be connected and registered for the disconnect
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
    if (!iUsbNotifier->IsConfigured() || !iPrinterConnectRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
        TRequestStatus* status = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
        User::RequestComplete(status, KErrNotReady);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
        return;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
    iOutEvent = &aParam;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
    iDpsEventRequest = &aStatus;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
    *iDpsEventRequest = KRequestPending;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
    iDpsOperator->ScriptReceiver()->WaitForReceive();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
    IF_DEBUG(Print(_L("<<<DpsEngine::DpsEventNotify")));
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
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
//       
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
EXPORT_C void CDpsEngine::CancelDpsEventNotify()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
    IF_DEBUG(Print(_L("DpsEngine::CancelDpsEventNotify")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
    if (iDpsEventRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
        User::RequestComplete(iDpsEventRequest, KErrCancel);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
        iDpsOperator->ScriptReceiver()->Cancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
        }  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
//     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
EXPORT_C void CDpsEngine::GetDpsConfigL(TDpsConfigPrintReq& aConfig)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
    IF_DEBUG(Print(_L(">>>DpsEngine::GetDpsConfigL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   275
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   276
    RFs fs = iDpsOperator->Trader()->FileHandle()->FileSession();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   277
    RResourceFile resource;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   278
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   279
    TBuf<KResource> resourceFile(PathInfo::RomRootPath());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   280
    TBuf<KResource> length(KDpsResource);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   281
    resourceFile.SetLength(KDriver + length.Length());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   282
    resourceFile.Replace(KDriver, length.Length(), KDpsResource);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   283
    IF_DEBUG(Print(_L("file is %S"), &resourceFile));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   284
    resource.OpenL(fs, resourceFile);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   285
    CleanupClosePushL(resource);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   286
    resource.ConfirmSignatureL(KDpsResourceVersion);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   287
    HBufC8* id = resource.AllocReadLC(DPS_CONFIG);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   288
    TResourceReader reader;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   289
    reader.SetBuffer(id);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   290
    TInt count = static_cast<TInt>(reader.ReadUint8());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   291
    for (TInt i = 0; i < count; i++)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   292
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   293
        TDpsVersion version;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   294
        version.iMajor = static_cast<TInt>(reader.ReadUint8());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   295
        version.iMinor = static_cast<TInt>(reader.ReadUint8());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   296
        aConfig.iDpsVersions.Append(version); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   297
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   298
    TPtrC vendorString = reader.ReadTPtrC(); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   299
    aConfig.iVendorName.Copy(vendorString);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   300
    TDpsVersion vendorVersion;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   301
    vendorVersion.iMajor = static_cast<TInt>(reader.ReadUint8());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   302
    vendorVersion.iMinor = static_cast<TInt>(reader.ReadUint8());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   303
    aConfig.iVendorVersion = vendorVersion;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   304
    TPtrC productString = reader.ReadTPtrC();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   305
    aConfig.iProductName.Copy(productString);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   306
    TPtrC SerialNo = reader.ReadTPtrC();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   307
    aConfig.iSerialNo.Copy(SerialNo);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   308
    CleanupStack::PopAndDestroy(id); 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   309
    CleanupStack::PopAndDestroy(&resource);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   310
    IF_DEBUG(Print(_L("<<<DpsEngine::GetDpsConfigL")));
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
EXPORT_C const TDesC& CDpsEngine::DpsFolder() const
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   318
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   319
    return iDpsFolder;
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
TDpsEvents* CDpsEngine::Event() const
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   327
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   328
    return iOutEvent;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   329
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   330
 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   331
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   332
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   333
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   334
//         
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   335
RPtp& CDpsEngine::Ptp()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   336
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   337
    return iPtp;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   338
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   339
  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   340
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   341
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   342
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   343
//         
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   344
TDpsXmlString* CDpsEngine::DpsParameters() const
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   345
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   346
    return iDpsParameters;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   347
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   348
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   349
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   350
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   351
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   352
//    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   353
TRequestStatus*& CDpsEngine::EventRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   354
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   355
    return iDpsEventRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   356
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   357
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   358
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   359
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   360
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   361
//            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   362
TRequestStatus*& CDpsEngine::OperationRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   363
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   364
    return iDpsOperationRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   365
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   366
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   367
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   368
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   369
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   370
//                
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   371
TRequestStatus*& CDpsEngine::PrinterConnectRequest()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   372
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   373
    return iPrinterConnectRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   374
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   375
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   376
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   377
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   378
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   379
//               
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   380
void CDpsEngine::SetDpsFolder(const TDesC& aFolder)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   381
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   382
    iDpsFolder.Copy(aFolder);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   383
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   384