cbsref/telephonyrefplugins/atltsy/atcommand/generic/src/atmanager.cpp
author hgs
Thu, 07 Oct 2010 11:24:36 +0100
changeset 76 91e0f833dd8b
parent 44 8b72faa1200f
permissions -rw-r--r--
201039_01
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
// 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
// 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
// use include
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
#include "atmanager.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
#include "activecommandstore.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
#include "mslogger.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
// CAtManager::NewL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
// ---------------------------------------------------------------------------	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
CAtManager* CAtManager::NewL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    28
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::NewL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    29
	CAtManager *self = CAtManager::NewLC();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    30
	CleanupStack::Pop(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    31
	return self;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    32
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    33
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    34
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
// CAtManager::NewLC
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
// ---------------------------------------------------------------------------	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
CAtManager* CAtManager::NewLC()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::NewLC()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
	CAtManager *self = new (ELeave) CAtManager;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
	CleanupStack::PushL(self);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
	self->ConstructL();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
	return self;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
// CAtManager::~CAtManager
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
// ---------------------------------------------------------------------------	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
CAtManager::~CAtManager()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::~CAtManager()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
	delete iActiveCommandStore;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
	iActiveCommandStore = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
// CAtManager::CAtManager
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
// ---------------------------------------------------------------------------	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
CAtManager::CAtManager()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::CAtManager()"));
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
// CAtManager::ConstructL
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 CAtManager::ConstructL()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::ConstructL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
	iActiveCommandStore = CActiveCommandStore::NewL();
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
// CAtManager::SetSolicitedAtCommand
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 CAtManager::SetSolicitedAtCommand(CAtCommandBase* aSolicitedCommand)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::SetSolicitedAtCommand()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
	iSolicitedCommand = aSolicitedCommand;
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
// CAtManager::GetActiveCommandStore
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
CActiveCommandStore* CAtManager::GetActiveCommandStore() const
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
	return iActiveCommandStore;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
// CAtManager::ReadOrWriteComplete
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
// ---------------------------------------------------------------------------	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
void CAtManager::ReadOrWriteComplete(TAtEventSource aEvent, TInt aStatus)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::AtCommandReadOrWriteComplete()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
	LOGTEXT3(_L8("[Ltsy] aEvent = %d, aStatus = %d"), aEvent, aStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
    if (aEvent == EWriteCompletion)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
		if (iSolicitedCommand != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
			if(aStatus == KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
				// add this active AT Command in the first place of the store
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
				iActiveCommandStore->AddSolicitedAtCommand(iSolicitedCommand);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
			else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
				{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
				iSolicitedCommand = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
				}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
			iSolicitedCommand->GenericEventSignal(aEvent, aStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
    else if (aEvent == EReadCompletion)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
		if (aStatus != KErrNone)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
			// check if there is active solicited AT command in the AT active command store
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
			if((iActiveCommandStore->GetActiveCommandArray())[0] != NULL)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
	          {
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
	          iSolicitedCommand->GenericEventSignal(aEvent, aStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
	          }
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
			
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
			iSolicitedCommand = NULL;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
    else if(aEvent == ETimeoutCompletion)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
    	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
		if(iSolicitedCommand)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
			iSolicitedCommand->GenericEventSignal(ETimeoutCompletion, aStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
			iSolicitedCommand = NULL;
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
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   146
// ---------------------------------------------------------------------------
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   147
// CAtManager::NotifyOneLineFoundL
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   148
// other items were commented in a header
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   149
// ---------------------------------------------------------------------------	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   150
TBool CAtManager::NotifyOneLineFoundL(TInt aStatus, const TDesC8& aLineBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   151
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   152
	LOGTEXT(_L8("[Ltsy] Starting CAtManager::NotifyOneLineFoundL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   153
		
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   154
	RPointerArray<CAtCommandBase>& atCommands = iActiveCommandStore->GetActiveCommandArray();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   155
	TInt count = atCommands.Count();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   156
	LOGTEXT2(_L8("[Ltsy] count = %d"), count);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   157
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   158
	TBool atCommandFound(EFalse);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   159
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   160
	for (TInt n = 0; !atCommandFound && n < count; n++)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   161
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   162
		CAtCommandBase* atCommand = atCommands[n];
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   163
		if ((atCommand != NULL) && atCommand->MatchExpectString(aLineBuf))
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   164
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   165
			atCommandFound = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   166
			atCommand->ParseResponseL(aLineBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   167
			atCommand->GenericEventSignal(EReadCompletion, aStatus);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   168
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   169
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   170
	LOGTEXT(_L8("[Ltsy] End CAtManager::NotifyOneLineFoundL()"));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   171
	return ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   172
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   173
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   174
// End of file