mtpdataproviders/mtppictbridgedp/pictbridgeengine/src/dpsscriptreceiver.cpp
author hgs
Thu, 04 Nov 2010 15:31:42 +0800
changeset 60 841f70763fbe
parent 49 c20dd21d1eb4
permissions -rw-r--r--
201044_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2006, 2007 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  This class implements the dps script receiving function. 
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
#include <f32file.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    19
#include "dpsscriptreceiver.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#include "dpsstatemachine.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include "pictbridge.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include "dpsconst.h"
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    23
#include "mtpdebug.h"
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    24
#include "OstTraceDefinitions.h"
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    25
#ifdef OST_TRACE_COMPILER_IN_USE
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    26
#include "dpsscriptreceiverTraces.h"
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
CDpsScriptReceiver* CDpsScriptReceiver::NewL(CDpsStateMachine* aOperator)								 	     
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
    CDpsScriptReceiver* self = new(ELeave) CDpsScriptReceiver(aOperator);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
    return self;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
CDpsScriptReceiver::CDpsScriptReceiver(CDpsStateMachine* aOperator) :
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
    CActive(EPriorityNormal), iOperator(aOperator),
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
    iFileNameAndPath(KDpsHostResponseFileName)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    47
    OstTraceFunctionEntry0( CDPSSCRIPTRECEIVER_CDPSSCRIPTRECEIVER_CONS_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    48
    CActiveScheduler::Add(this);  
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    49
    WaitForReceive();
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    50
    OstTraceFunctionExit0( CDPSSCRIPTRECEIVER_CDPSSCRIPTRECEIVER_CONS_EXIT );
29
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
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
CDpsScriptReceiver::~CDpsScriptReceiver()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    59
    OstTraceFunctionEntry0( CDPSSCRIPTRECEIVER_CDPSSCRIPTRECEIVER_DES_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
    Cancel();
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    61
    OstTraceFunctionExit0( CDPSSCRIPTRECEIVER_CDPSSCRIPTRECEIVER_DES_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
//   
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
void CDpsScriptReceiver::WaitForReceive()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    70
    OstTraceFunctionEntry0( CDPSSCRIPTRECEIVER_WAITFORRECEIVE_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    71
    if (!IsActive())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    72
        {	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    73
        iOperator->DpsEngine()->Ptp().ObjectReceivedNotify(KDpsScriptFile, 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    74
            iFileNameAndPath, iStatus, EFalse);        
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
        SetActive();		    	
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    76
        }		
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
    77
    OstTraceFunctionExit0( CDPSSCRIPTRECEIVER_WAITFORRECEIVE_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
TInt CDpsScriptReceiver::GetFileName(TDes& aFileName)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
    TParse p;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
    TInt err = p.Set(iFileNameAndPath, NULL, NULL);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
    if (KErrNone == err)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
        aFileName.Copy(p.NameAndExt());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
    return err;    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
    }
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
const TDesC& CDpsScriptReceiver::FileNameAndPath()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   101
    return iFileNameAndPath;
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
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
void CDpsScriptReceiver::RunL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   110
    OstTraceFunctionEntry0( CDPSSCRIPTRECEIVER_RUNL_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   111
    OstTraceExt1( TRACE_NORMAL, CDPSSCRIPTRECEIVER_RUNL, "iFileNameAndPath %S", iFileNameAndPath );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    // in the certain error case, it is possible that the printer sending
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
    // the device status before the UI is ready to receive this event.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
    // in this case, pictbridge engine still does not get the ptp folder
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   115
    // setting from the stack. 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   116
    // if we receive script from host, the stack has started. so we check if
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   117
    // we already get the ptp folder here.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   118
    if (!iOperator->DpsEngine()->DpsFolder().Length())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
        iOperator->DpsEngine()->SetDpsFolder(
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
            iOperator->DpsEngine()->Ptp().PtpFolder());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
    if (KErrNone == iStatus.Int())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
        TFileName receive;
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   126
        LEAVEIFERROR(GetFileName(receive),
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   127
                OstTraceExt2( TRACE_ERROR, DUP3_CDPSSCRIPTRECEIVER_RUNL, 
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   128
                        "Gets the file name from %S failed! error code %d",receive, munged_err  ));
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   129
                
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   130
        OstTraceExt1( TRACE_NORMAL, DUP1_CDPSSCRIPTRECEIVER_RUNL, "received file is %S", receive );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   131
         // reply from Host is received    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   132
        if (!receive.Compare(KDpsHostResponseFileName))
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   133
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   134
            iOperator->ScriptReceivedNotifyL(ETrue);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   135
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   136
        // request from Host is received    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   137
        else if (!receive.Compare(KDpsHostRequestFileName))
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   138
            {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   139
            iOperator->ScriptReceivedNotifyL(EFalse);    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   140
            }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   141
        WaitForReceive();    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   142
        }                
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   143
    else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   144
    	{
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   145
        OstTrace1( TRACE_ERROR, DUP2_CDPSSCRIPTRECEIVER_RUNL, "the iStatus is wrong!!! %d", iStatus.Int() );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   146
        iOperator->Error(iStatus.Int());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   147
        }    
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   148
    OstTraceFunctionExit0( CDPSSCRIPTRECEIVER_RUNL_EXIT );
29
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
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   154
//    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   155
void CDpsScriptReceiver::DoCancel()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   156
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   157
    OstTraceFunctionEntry0( CDPSSCRIPTRECEIVER_DOCANCEL_ENTRY );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   158
    iOperator->DpsEngine()->Ptp().CancelObjectReceivedNotify();
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   159
    OstTraceFunctionExit0( CDPSSCRIPTRECEIVER_DOCANCEL_EXIT );
29
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
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   165
//	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   166
TInt CDpsScriptReceiver::RunError(TInt aError)	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   167
    {
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   168
    OstTraceFunctionEntry0( CDPSSCRIPTRECEIVER_RUNERROR_ENTRY );
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   169
    OstTraceDef1( OST_TRACE_CATEGORY_PRODUCTION, TRACE_IMPORTANT, CDPSSCRIPTRECEIVER_RUNERROR, 
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   170
            "error code %d", aError);
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   171
    // if error happened cancel the outstanding request
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   172
    Cancel();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   173
    iOperator->Error(aError);
49
c20dd21d1eb4 201035_05
hgs
parents: 29
diff changeset
   174
    OstTraceFunctionExit0( CDPSSCRIPTRECEIVER_RUNERROR_EXIT );
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   175
    return KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   176
    }