mtpdataproviders/mtppictbridgedp/pictbridgeengine/inc/pictbridge.h
author hgs
Fri, 23 Jul 2010 18:35:35 +0800
changeset 35 c4c427c00f31
parent 29 3ae5cb0b4c02
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
#ifndef PICTBRIDGE_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#define PICTBRIDGE_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include "dpsdefs.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include <rptp.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
class TDpsXmlString;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
class CDpsUsbNotifier;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
class TMDpsOperation;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
class TDpsEvents;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
class CDpsStateMachine;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
class TDpsConfigPrintReq;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
NONSHARABLE_CLASS(CDpsEngine) : public CBase
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
    public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
        enum TConnectionStatus
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
            ENotConnected = 1,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
            // ptp printer is connected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
            EPrinterConnected,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
            // ptp printer is disconnected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
            EPrinterDisconnected,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
            // in ptp personality, but device other than printer connected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
            EOtherConnected,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
            // in personality other than ptp and device is connected 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
            EWrongPrintModeConnected
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
            };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
	        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
    public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
        *   The client should always call this function to get the Dps 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
        *   engine object.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
        *   This function guarantees there is only one engine in the 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
        *   thread, a singleton.  	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
        *   @return CDpsEngine* the only Dps Engine instance in a thread
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
        *   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
        IMPORT_C static CDpsEngine* GetEngineL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
        *	Deletes the dps engine object. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
        IMPORT_C void Delete();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
        *	Sets the personality to PTP. This must be the first call after 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
        *   the client has got the CDpsEngine object and should only be
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
        *   called once.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
        *   @param aStatus the asynchronous request and it has the connect
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
        *   state after returned. The client can use this value to get the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
        *   current connect status.        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
        IMPORT_C void SetPrintMode(TRequestStatus& aStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
        							 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
        *   Cancels the SetPrintMode request        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
        */        							 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
        IMPORT_C void CancelPrintMode();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
						     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
        *   Registers connection notification. This function can inform 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
        *   the connection and the disconnect, two states. Connection: the
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
        *   personality has been set to PTP by SetPrintMode, but the cable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
        *   is not connected at the moment. The connection will be informed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
        *   by this function. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
        *   Disconnect: the user has unplugged the cable or changed 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
        *   personality.    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
        *   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
        *   @param aStatus the asynchronous request status and it has the 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
        *   connect state after returned.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
        */     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
        IMPORT_C void ConnectStateNotify(TRequestStatus& aStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
				     					
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
        *   Registers Dps event notification. There are two events: jobStatus
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
        *   and deviceStatus. This function is called immediately after 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
        *   ConnecSatetNotify call. After this call, the client should issue 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
        *   ConfigPrintService request to configure the printer.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
        *   @param aParam this parameter serves as out parameter. After
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
        *   processing the event from the printer, Dps engine will put
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
        *   the correct value to this parameter. As the result, the client
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
        *   can get the event by accessing this parameter after this request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
        *   gets answered. So the client should have it as a class variable
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
        *   @param aStatus the asynchronous status. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
        IMPORT_C void DpsEventNotify(TDpsEvents& aParam, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
                                     TRequestStatus& aStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
        *   Cancels Dps event notification. The client only needs to call
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
        *   this to reset the state of the dps engine and it must be called
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
        *   after CancelDpsRequest().
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
        IMPORT_C void CancelDpsEventNotify();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
        *   Starts a Dps operation.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
        *   If this function returned with error, e.g. leaving, the client
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
        *   should call CancelDpsRequest(), to cancel the pending request.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
        *   @param aRequest the Dps operation. It includes both request and 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
        *   reply. The client should fill in the request parameter and the 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
        *   Dps engine will fill in the reply paramter when this operation
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
        *   is finished. The client should declare it as a class variable.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
        *   @param aStatus the asynchronous status
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
        IMPORT_C void DoDpsRequestL(TMDpsOperation* aRequest, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
                                    TRequestStatus& aStatus);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
		
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
        *   Cancels the dps operation. Calling this will reset the state of 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
        *   the dps engine, either because of error happened or the client
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
        *   wants to do this on purpose. In most cases, the client never need
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
        *   to cancel the ongoing request because the request will end very 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
        *   quick, normally within several million seconds. The client normally
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
        *   waits until the request is finished, either succesfully or
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
        *   failed indicated by timeout.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
        */        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
        IMPORT_C void CancelDpsRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
        *   Reads the phone dps configuration from the resource file
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
        *   @param aConfig the dps configuration is returned by this parameter
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
        IMPORT_C void GetDpsConfigL(TDpsConfigPrintReq& aConfig);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
        *   @since 3.2
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
        *   @lib pictbridge.lib
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
        *
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
        *   Gets the folder where the printer configure file should be kept. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
        *   The print App needs a file to store the printer configure when it
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
        *   first calls configPrintService Dps request. The print app can 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
        *   quit at anytime while the ptpserver (stack) is still running. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
        *   Since the ptpstack is keeping the session with the printer, the 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
        *   printer always does not excute the second onward 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
        *   configPrintService request. As the result, the restarted print app
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
        *   cannot get the printer configure. So there must be a file for 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
        *   keeping this information and it will be deleted by ptpserver when
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
        *   it quits, e.g. when the connection with the printer is lost.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
        *   @return TDesC& the folder descriptor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
        IMPORT_C const TDesC& DpsFolder() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   193
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   194
        *   Gets the Dps event object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   195
        *   @return TDpsEvents* the pointer to the Dps event.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   196
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   197
        TDpsEvents* Event() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   198
            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   199
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   200
        *  Gets the ptp server reference
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   201
        *  @return RPtp& the reference to ptp server.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   202
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   203
        RPtp& Ptp();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   204
            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   205
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   206
        *  Gets the dps constant strings
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   207
        *  @return TDpsGlobalData* the pointer to dps constant strings.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   208
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   209
        TDpsXmlString* DpsParameters() const;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   210
         
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   211
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   212
        * @return dps event notify AO status
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   213
        *   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   214
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   215
        TRequestStatus*& EventRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   216
            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   217
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   218
        * @return dps request AO status
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   219
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   220
        TRequestStatus*& OperationRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   221
         
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   222
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   223
        * @return connection notify AO status
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   224
        */               
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   225
        TRequestStatus*& PrinterConnectRequest();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   226
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   227
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   228
        *  Sets the Dps file folder. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   229
        *  @param aFolder the foler location, readed from Ptp server/stack 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   230
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   231
        void SetDpsFolder(const TDesC& aFolder);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   232
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   233
            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   234
    private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   235
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   236
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   237
        *   Prohibits the destructor called by the client. To delete engine object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   238
        *   Delete() must be called
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   239
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   240
        ~CDpsEngine();  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   241
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   242
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   243
        *   Second phase constructor. Operations which might leave should 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   244
        *   be called here
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   245
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   246
        void ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   247
              
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   248
    private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   249
        // string constant, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   250
        TDpsXmlString* iDpsParameters;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   251
        // dps engine state machine, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   252
        CDpsStateMachine *iDpsOperator;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   253
        // dps operation AO request, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   254
        TRequestStatus* iDpsOperationRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   255
        // dps event AO request, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   256
        TRequestStatus* iDpsEventRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   257
        // printer connection/disconnection AO request, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   258
        TRequestStatus* iPrinterConnectRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   259
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   260
        // usb cable connection/disconnection notifier, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   261
        CDpsUsbNotifier *iUsbNotifier;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   262
                
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   263
        // out parameter for events (NotifyJobStatus and
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   264
        // NotifyDeviceStauts), it is
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   265
        // passed from UI engine, not owned by this class  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   266
        TDpsEvents* iOutEvent;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   267
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   268
        // Ptp Server session, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   269
        RPtp    iPtp;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   270
        // the folder where all dps releated files should be stored              
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   271
        TFileName iDpsFolder;  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   272
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   273
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   274
#endif