mtpdataproviders/mtppictbridgedp/pictbridgeengine/src/dpsstatemachine.cpp
author hgs
Fri, 23 Jul 2010 18:35:35 +0800
changeset 35 c4c427c00f31
parent 29 3ae5cb0b4c02
child 47 63cf70d3ecd8
permissions -rw-r--r--
201029_04
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
29
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     1
/*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     2
* Copyright (c) 2006, 2007 Nokia Corporation and/or its subsidiary(-ies).
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     3
* All rights reserved.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     8
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
     9
* Initial Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    11
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    12
* Contributors:
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    13
*
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    14
* Description:  This class implements the dps state machine. 
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 <e32debug.h>
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    20
#include "dpsstatemachine.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    21
#include "dpsscriptreceiver.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    22
#include "dpsscriptsender.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    23
#include "dpstransaction.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    24
#include "dpsconst.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    25
#include "pictbridge.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    26
#include "dpsparam.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    27
#include "dpsoperation.h"
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    28
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    29
#ifdef _DEBUG
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    30
#	define IF_DEBUG(t) {RDebug::t;}
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    31
#else
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    32
#	define IF_DEBUG(t)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    33
#endif
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    34
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    35
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    36
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    37
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    38
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    39
CDpsStateMachine* CDpsStateMachine::NewL(CDpsEngine* aEngine)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    40
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    41
    IF_DEBUG(Print(_L("CDpsStateMachine::NewL")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    42
    CDpsStateMachine* self = new(ELeave) CDpsStateMachine(aEngine);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    43
    CleanupStack::PushL(self);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    44
    self->ConstructL();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    45
    CleanupStack::Pop();
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    46
    return self;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    47
    }
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
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    53
CDpsStateMachine::~CDpsStateMachine()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    54
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    55
    IF_DEBUG(Print(_L(">>>~CDpsStateMachine")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    56
    delete iTrader;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    57
    iTrader = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    58
    delete iScriptReceiver;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    59
    iScriptReceiver = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    60
    delete iScriptSender;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    61
    iScriptSender = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    62
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    63
    delete iIdleState; iIdleState = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    64
    delete iSendingReqState; iSendingReqState = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    65
    delete iWaitingRepState; iWaitingRepState = NULL;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    66
    delete iSendingRepState; iSendingRepState = NULL;	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    67
    IF_DEBUG(Print(_L("<<<~CDpsStateMachine")));	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    68
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    69
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
CDpsStateMachine::CDpsStateMachine(CDpsEngine* aEngine) : 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    75
    iEngine(aEngine),iOperation(EDpsOpEmpty), iEvent(EDpsEvtEmpty), 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    76
    iCurError(KErrNone)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    77
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    78
    IF_DEBUG(Print(_L(">>>CDpsStateMachine::Ctor")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    79
    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    80
    IF_DEBUG(Print(_L("<<<CDpsStateMachine::Ctor")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    81
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    82
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    83
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    84
// 
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    85
// ---------------------------------------------------------------------------
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    86
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    87
void CDpsStateMachine::ConstructL()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    88
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    89
    IF_DEBUG(Print(_L(">>>CDpsStateMachine::ConstructL")));	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    90
    iIdleState = new(ELeave) TDpsIdleState(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    91
    iSendingReqState = new(ELeave) TDpsSendingReqState(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    92
    iWaitingRepState = new(ELeave) TDpsWaitingRepState(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    93
    iSendingRepState = new(ELeave) TDpsSendingRepState(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    94
    iCurState = iIdleState;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    95
    iTrader = CDpsTransaction::NewL(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    96
    iScriptReceiver = CDpsScriptReceiver::NewL(this);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    97
    iScriptSender = CDpsScriptSender::NewL(this);	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    98
    IF_DEBUG(Print(_L("<<<CDpsOperator::ConstructL")));	
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
    99
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   100
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
void CDpsStateMachine::StartTransactionL(TMDpsOperation* aRequest)
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   106
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   107
    IF_DEBUG(Print(_L(">>>CDpsStateMachine::StartTransaction")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   108
    iMOperation = aRequest;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   109
    iOperation = (TDpsOperation)iMOperation->iOperation;    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   110
    iTrader->CreateRequestL(aRequest);
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   111
    iCurState = iSendingReqState;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   112
    IF_DEBUG(Print(_L("<<<CDpsStateMachine::StartTransaction")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   113
    }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   114
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
//
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   119
void CDpsStateMachine::Initialize()
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   120
    {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   121
    IF_DEBUG(Print(_L(">>>CDpsStateMachine::Initialize")));
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   122
    iOperation = EDpsOpEmpty;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   123
    iEvent = EDpsEvtEmpty;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   124
    iCurError = KErrNone;
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   125
    if (CurState() != IdleState())
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   126
        {
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   127
        SetState(IdleState());
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   128
        }
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   129
    IF_DEBUG(Print(_L("<<<CDpsStateMachine::Initialize")));    
3ae5cb0b4c02 201025_07
hgs
parents:
diff changeset
   130
    }