mtpdataproviders/mtppictbridgedp/pictbridgeengine/inc/dpstransaction.h
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 29 3ae5cb0b4c02
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 creates and parses dps operations. 
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 DPSTRANSACTION_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#define DPSTRANSACTION_H
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include <e32base.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include "dpsdefs.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
#include "dpsoperation.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
class 	CDpsFile;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
class 	CDpsEngine;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
class   CDpsXmlGenerator;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
class	CDpsXmlParser;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
class 	CDpsScriptSender;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
class   TDpsVersion;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
class   CDpsStateMachine;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
class   TMDpsOperation;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
*   This class creates and parses dps operation (request and reply)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
NONSHARABLE_CLASS(CDpsTransaction) : public CBase
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
    public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
        *   Two phase constructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
        *   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
        *   @param iOperator the pointer to dps operation object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
        *   @return the dps transaction instance
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
        static CDpsTransaction* NewL(CDpsStateMachine* iOperator);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    50
        *   Destructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    51
        */        							 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    52
        ~CDpsTransaction();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
    public:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
        *   Creates the dps operation request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
        *   @param aParam the dps operation parameters
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
    	void CreateRequestL(TMDpsOperation* aOperation);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    	*   Parses dps operation script
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
    	*   @param aReply if the script is the reply from the host
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
    	*   aReply is ETrue, otherwise the script must be the request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
    	*   from the device and aReply is EFalse
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    	void ParseScriptL(TBool aReply);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    70
    	*   @return ETrue if the script is the reply from the host,
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    	*   EFalse if the script is the request from the host
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
    	inline TBool IsReply();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
    	*   @return the CDpsXmlParser object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    	inline CDpsXmlParser* Parser();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
    	    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
    	*   @return the CDpsXmlGenerator object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
    	inline CDpsXmlGenerator* Generator();    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
    	    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    	*   @return the CDpsEngine object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    	*/    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
        inline CDpsEngine* Engine();
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
    	*   Converts the version in descriptor tpye to TDpsVersion type
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
    	*   @param aParser the version in descriptor 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
    	*   @param aVersoin the version in TDpsVersion and will be returned
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
    	*   @return KErrNone if OK, other system error if failed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
    	*/        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
        TInt ConvertVersion(TLex8& aParser, TDpsVersion& aVersion);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
        *   @return CDpsStateMachine pointer to dps state machine object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   102
        inline CDpsStateMachine* Operator();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   103
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   104
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   105
        *   Parses the string of percentage to integer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
        *   @param aPer the string of percentage to be parsed
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
        *   @return TInt the percentage in integer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
        */    			
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
        TInt ParsePercentage(const TDes8& aPer);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
        *   @return the error of result in integer
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
        inline TInt ResultErr();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
                    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
            
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
        *   @return CDpsFile pointer to dps file object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
        inline CDpsFile* FileHandle();
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
        void HandleHostRequestError(TInt aErr);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
                    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
    private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
        *   Default constructor
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
        *   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
        *   @param iOperator the pointer to the dps operator 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
        */	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
    	CDpsTransaction(CDpsStateMachine* iOperator);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
    	*   Second phase constructor. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
    	void ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
    	*   Creates the dps event reply.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
    	*   @param aArguments dps event arguments
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    	*   @param aResult the result of the reply. See Dps spec for
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
    	*   detail result value
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   145
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
    	void CreateEventReplyL(TDpsEvent aEvent, const TDpsResult& aResult);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   148
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   149
    	*   Creates the dps request reply based on host dps request.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   150
    	*   There is only one dps request from host (others are from device) -
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   151
    	*   GetFileID
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   152
    	*   @param aArgs the dps argument from the dps xml script
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   153
    	*   @param aResult the reply result to be filling to the dps xml script
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
    	void CreateRequestReplyL(const TDpsArgArray& aArgs, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
                                 const TDpsResult& result);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   157
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
        /**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   159
        *   Removes the unprintable chars (LF, CR, TAB and spaces) between 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   160
        *   two XML attributes. It seems
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   161
        *   sybmian XML framework does filter out these character even though
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   162
        *   they are not belong to the attribute. Some printers (Cannon) send
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   163
        *   Dps request (XML script) in human readable format, e.g. including
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   164
        *   LF, CR and spaces among XML attributes.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
        *   @param aScript the XML script to be filtered out
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
        */
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
    	void Filter(TDes8& aScript);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   168
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   169
    	/**
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   170
    	*   Changes the file path for GetFileID request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    	*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
    	*/
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
    	void SubstitutePath(TDes8& aPath);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   174
    	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
    private:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   177
    	// the pointer to dps operator object
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   178
    	// not owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   179
        CDpsStateMachine* iOperator;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   180
        // the pointer to xml generator object, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   181
        CDpsXmlGenerator *iXmlGen;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   182
        // the pointer to xml parser object, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   183
        CDpsXmlParser *iXmlPar; 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   184
        // the pointer to file generator object, owned by this class
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   185
        CDpsFile *iFile;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   186
                
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   187
        // the current parsed script is reply or request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   188
        TBool iReply;  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   189
    };
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   190
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   191
#include "dpstransaction.inl"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   192
#endif