cbsref/telephonyrefplugins/atltsy/atcommand/callcontrol/src/atanswer.cpp
author hgs
Mon, 09 Aug 2010 17:43:08 +0100
changeset 59 ac20d6a0a19d
parent 44 8b72faa1200f
permissions -rw-r--r--
201029_06
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
44
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     1
// Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     2
// All rights reserved.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     7
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     8
// Initial Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    10
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    11
// Contributors:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    12
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    13
// Description:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    14
// @file atanswer.cpp
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
// This contains CATAnswer which answering incomging call.
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
// 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
//system include
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
//user include
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
#include "atanswer.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
#include "ltsycallinformationmanager.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
#include "mslogger.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
//const define
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
const TInt KLtsyAnswerReadTimeOut = 20;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
_LIT8(KLtsyAnswerCallCommand, "ATA\r");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
// CATAnswer::NewL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
CATAnswer* CATAnswer::NewL(CGlobalPhonemanager& aGloblePhone,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
						   CCtsyDispatcherCallback& aCtsyDispatcherCallback)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::NewL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
	CATAnswer* self = CATAnswer::NewLC(aGloblePhone, aCtsyDispatcherCallback);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
	CleanupStack::Pop(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
	return self;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
// CATAnswer::NewLC
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
CATAnswer* CATAnswer::NewLC(CGlobalPhonemanager& aGloblePhone,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
						    CCtsyDispatcherCallback& aCtsyDispatcherCallback)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::NewLC()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
	CATAnswer* self = new (ELeave) CATAnswer(aGloblePhone, aCtsyDispatcherCallback);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
	CleanupStack::PushL(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
	self->ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
	return self;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
// CATAnswer::~CATAnswer
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
CATAnswer::~CATAnswer()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
// CATAnswer::SetAnswerCallId
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
void CATAnswer::SetAnswerCallId(TInt aCallId)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
	iCallId = aCallId;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
// CATAnswer::SetIsIsvCall
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
void CATAnswer::SetIsIsvCall(TBool aIsIsvCall)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
	iIsIsvCall = aIsIsvCall;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
// CATAnswer::SetIsIsvCall
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
CATAnswer::CATAnswer(CGlobalPhonemanager& aGloblePhone,
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
		             CCtsyDispatcherCallback& aCtsyDispatcherCallback)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
					 :CAtCommandBase(aGloblePhone, aCtsyDispatcherCallback)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::CATAnswer()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
	iIOStatus = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
	iATResult = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
	iAnswerStep = EATNotInProgress;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
// CATAnswer::ConstructL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
void CATAnswer::ConstructL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::ConstructL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
	CAtCommandBase::ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
	AddExpectStringL(KLtsyNoCarrierString);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
	//Set read and write timeout
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
	SetTimeOut(KLtsyDefaultWriteTimeOut, KLtsyAnswerReadTimeOut);	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
// CATAnswer::ExecuteCommand
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
void CATAnswer::ExecuteCommand()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::ExecuteCommand()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
	//Write AT command
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
	iTxBuffer.Copy(KLtsyAnswerCallCommand);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
	Write();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
	iAnswerStep = EATWaitForWriteComplete;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
// CATAnswer::StartRequest
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
void CATAnswer::StartRequest()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::StartRequest()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
	ExecuteCommand();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   142
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   143
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   144
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   145
// CATAnswer::ParseResponseL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
void CATAnswer::ParseResponseL(const TDesC8& aResponseBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::ParseResponseL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
	if (aResponseBuf.Match(KLtsyOkString) == 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
		iATResult = KErrNone;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
	else if (aResponseBuf.Match(KLtsyErrorString) == 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
		iATResult = KErrArgument;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
	else if (aResponseBuf.Match(KLtsyNoCarrierString) == 0)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
		iATResult = KErrEtelNoCarrier;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
// CATAnswer::HandleIOError
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
void CATAnswer::HandleIOError()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::HandleIOError()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
	//Call back
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   175
	iCtsyDispatcherCallback.CallbackCallControlAnswerComp(iIOStatus, iCallId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   176
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   177
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   178
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   179
// CATAnswer::HandleResponseError
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   180
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   181
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   182
void CATAnswer::HandleResponseError()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   183
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   184
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::HandleResponseError()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   185
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   186
	//Call back
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   187
	iCtsyDispatcherCallback.CallbackCallControlAnswerComp(iATResult, iCallId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   188
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   189
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   190
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   191
// CATAnswer::HandleConnectedComplete
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   192
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   193
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   194
void CATAnswer::HandleConnectedComplete()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   195
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   196
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::HandleConnectedComplete()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   197
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   198
	//Setting call states
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   199
	iCtsyDispatcherCallback.CallbackCallControlNotifyCallStatusChangeInd(KErrNone, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   200
			                                                             iCallId, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   201
			                                                             RMobileCall::EStatusAnswering);	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   202
		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   203
	iCtsyDispatcherCallback.CallbackCallControlNotifyCallStatusChangeInd(KErrNone, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   204
			                                                             iCallId, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   205
			                                                             RMobileCall::EStatusConnected);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   206
			                                                             
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   207
    //Call back
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   208
	iCtsyDispatcherCallback.CallbackCallControlAnswerComp(KErrNone, iCallId);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   209
				                                                             						
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   210
	//Change Call State to active
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   211
	TLtsyCallInformation& tCallInfo(iPhoneGlobals.GetCallInfoManager().GetCallInformationByCallId(iCallId));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   212
	if (tCallInfo.GetCallIdIsUsedInfo() == TLtsyCallInformation::EUsed)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   213
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   214
		tCallInfo.SetCallState(TLtsyCallInformation::EActiveCall);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   215
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   216
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   217
	//If exist other call , should set hold
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   218
	for (TInt n = KLtsyMinCallId; n <= KLtsyMaxCallId; n++)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   219
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   220
		if (n != iCallId)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   221
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   222
			TLtsyCallInformation& tCallInfo(iPhoneGlobals.GetCallInfoManager().GetCallInformationByCallId(n));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   223
			if (tCallInfo.GetCallIdIsUsedInfo() == TLtsyCallInformation::EUsed &&
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   224
				tCallInfo.GetCallState() != TLtsyCallInformation::EHeldCall )
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   225
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   226
				tCallInfo.SetCallState(TLtsyCallInformation::EHeldCall);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   227
				
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   228
				//Notify CTSY call state has changed
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   229
				iCtsyDispatcherCallback.CallbackCallControlNotifyCallStatusChangeInd(KErrNone, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   230
						                                                             n, 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   231
						                                                 RMobileCall::EStatusHold);				
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   232
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   233
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   234
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   235
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   236
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   237
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   238
// CATAnswer::Complete
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   239
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   240
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   241
void CATAnswer::Complete()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   242
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   243
	//Invoke base class complete
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   244
	CAtCommandBase::Complete();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   245
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   246
	//Let other command can use I/O port
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   247
	iPhoneGlobals.iEventSignalActive = EFalse;	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   248
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   249
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   250
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   251
// CATAnswer::EventSignal
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   252
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   253
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   254
void CATAnswer::EventSignal(TAtEventSource /*aEventSource*/, TInt aStatus)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   255
	{  
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   256
	LOGTEXT(_L8("[Ltsy CallControl] Starting CATAnswer::EventSignal()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   257
	LOGTEXT2(_L8("[Ltsy CallControl] aStatus = %d"),aStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   258
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   259
	iIOStatus = aStatus;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   260
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   261
	//I/O error
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   262
	if (iIOStatus != KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   263
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   264
		HandleIOError();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   265
		Complete();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   266
		return;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   267
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   268
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   269
	switch (iAnswerStep)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   270
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   271
		case EATWaitForWriteComplete:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   272
			iAnswerStep = EATReadComplete;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   273
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   274
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   275
		case EATReadComplete:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   276
			if (iATResult == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   277
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   278
				HandleConnectedComplete();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   279
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   280
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   281
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   282
				HandleResponseError();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   283
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   284
			Complete();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   285
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   286
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   287
		default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   288
			break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   289
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   290
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   291
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   292
//End of file