--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/cbsref/telephonyrefplugins/atltsy/atcommand/phonebook/src/atphbkgetphonestoreinfo.cpp Tue Jul 06 15:36:38 2010 +0300
@@ -0,0 +1,365 @@
+// Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
+// All rights reserved.
+// This component and the accompanying materials are made available
+// under the terms of "Eclipse Public License v1.0"
+// which accompanies this distribution, and is available
+// at the URL "http://www.eclipse.org/legal/epl-v10.html".
+//
+// Initial Contributors:
+// Nokia Corporation - initial contribution.
+//
+// Contributors:
+//
+// Description:
+// @file atphbkgetphonestoreinfo.cpp
+// This contains CAtPhbkGetPhoneStoreInfo which is used to get phonebook information
+//
+
+//system include
+#include <ctsy/ltsy/cctsydispatchercallback.h>
+#include <etelmm.h>
+
+//user include
+#include "atphbkgetphonestoreinfo.h"
+#include "mslogger.h"
+#include "ltsycommondefine.h"
+
+//constant defination
+_LIT8(KSetPhoneStore,"AT+CPBS=\"%S\"\r");
+_LIT8(KGetPhoneStoreInfo,"AT+CPBS?\r");
+_LIT8(KCPBSResponseString,"+CPBS:");
+_LIT8(KAdnPhonebook,"SM");
+_LIT8(KFdnPhonebook,"FD");
+_LIT8(KGetPrefMemCommand,"AT+CPMS?\r");
+_LIT8(KCPMSResponseString,"+CPMS:");
+
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::CAtPhbkGetPhoneStoreInfo
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+CAtPhbkGetPhoneStoreInfo::CAtPhbkGetPhoneStoreInfo(CGlobalPhonemanager& aGloblePhone,
+ CCtsyDispatcherCallback& aCtsyDispatcherCallback)
+ :CAtCommandBase(aGloblePhone,aCtsyDispatcherCallback)
+ {
+ LOGTEXT(_L8("CAtPhbkGetPhoneStoreInfo::CAtPhbkGetPhoneStoreInfo called"));
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::~CAtPhbkGetPhoneStoreInfo
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+CAtPhbkGetPhoneStoreInfo::~CAtPhbkGetPhoneStoreInfo()
+ {
+ LOGTEXT(_L8("CAtPhbkGetPhoneStoreInfo::~CAtPhbkGetPhoneStoreInfo called"));
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::NewLC
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+CAtPhbkGetPhoneStoreInfo* CAtPhbkGetPhoneStoreInfo::NewLC(CGlobalPhonemanager& aGloblePhone,
+ CCtsyDispatcherCallback& aCtsyDispatcherCallback)
+ {
+ CAtPhbkGetPhoneStoreInfo* self = new (ELeave)CAtPhbkGetPhoneStoreInfo(aGloblePhone,
+ aCtsyDispatcherCallback);
+ CleanupStack::PushL(self);
+ self->ConstructL();
+ return self;
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::NewL
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+CAtPhbkGetPhoneStoreInfo* CAtPhbkGetPhoneStoreInfo::NewL(CGlobalPhonemanager& aGloblePhone,
+ CCtsyDispatcherCallback& aCtsyDispatcherCallback)
+ {
+ CAtPhbkGetPhoneStoreInfo* self=CAtPhbkGetPhoneStoreInfo::NewLC(aGloblePhone,
+ aCtsyDispatcherCallback);
+ CleanupStack::Pop(self);
+ return self;
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::ConstructL
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::ConstructL()
+ {
+ CAtCommandBase::ConstructL();
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::SetPhoneStoreParam
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::SetPhoneStoreParam(const TDesC& aStoreName)
+ {
+ iStoreName = aStoreName;
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::StartRequest
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::StartRequest()
+ {
+ if( iStoreName.CompareF(KETelIccSmsStore) == KErrNone)
+ {
+ iState = ESetIccSmsStore;
+ iTxBuffer.Zero();
+ iTxBuffer.Copy(KGetPrefMemCommand);
+ Write();
+ }
+ else
+ {
+ ExecuteCommand();
+ }
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::ExecuteCommand
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::ExecuteCommand()
+ {
+ LOGTEXT(_L8("CAtPhbkGetPhoneStoreInfo::ExecuteCommand called"));
+ iState = ESetPhoneStore;
+ TPtrC8 storeName;
+ iTxBuffer.Zero();
+ if( iStoreName.CompareF(KETelIccFdnPhoneBook) == KErrNone )
+ {
+ storeName.Set(KFdnPhonebook);
+ }
+ else if( iStoreName.CompareF(KETelIccAdnPhoneBook) == KErrNone)
+ {
+ storeName.Set(KAdnPhonebook);
+ }
+ iTxBuffer.Format(KSetPhoneStore,&storeName);
+ Write();
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::EventSignal
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::EventSignal(TAtEventSource aEventSource, TInt aStatus)
+ {
+ LOGTEXT3(_L8("CAtPhbkGetPhoneStoreInfo::EventSignal aStatus=%D iSource=%D"),aStatus,aEventSource);
+
+ if(aStatus != KErrNone)
+ {
+ Complete();
+ iPhoneGlobals.iEventSignalActive = EFalse;
+ iCtsyDispatcherCallback.CallbackPhonebookGetPhoneStoreInfoComp(aStatus,iPhoneStoreInfo);
+ }
+ else
+ {
+ if( aEventSource == EWriteCompletion )
+ {
+ LOGTEXT(_L8("CAtPhbkGetPhoneStoreInfo::EventSignal,EWriteCompletion!"));
+ if( iState == ESetPhoneStore )
+ {
+ iState = ESetPhoneStoreComplete;
+ }
+ else if( iState == EGetPhoneStoreInfo )
+ {
+ iState = EGetPhoneStoreInfoComplete;
+ }
+ else if( iState ==ESetIccSmsStore )
+ {
+ iState = ESetIccSmsStoreComplete;
+ }
+ }
+ else
+ {
+ LOGTEXT(_L8("CAtPhbkGetPhoneStoreInfo::EventSignal,EReadCompletion!"));
+ if( iState == ESetPhoneStoreComplete )
+ {
+ Complete();
+ iPhoneGlobals.iEventSignalActive = EFalse;
+ if(iError == KErrNone)
+ {
+ iState = EGetPhoneStoreInfo;
+ GetPhoneStoreInfo();
+ }
+ else
+ {
+ iCtsyDispatcherCallback.CallbackPhonebookGetPhoneStoreInfoComp(iError,iPhoneStoreInfo);
+ }
+ }
+ else if( iState == EGetPhoneStoreInfoComplete )
+ {
+ iPhoneStoreInfo.iName = iStoreName;
+ Complete();
+ iPhoneGlobals.iEventSignalActive = EFalse;
+ iCtsyDispatcherCallback.CallbackPhonebookGetPhoneStoreInfoComp(iError,iPhoneStoreInfo);
+ }
+ else if( iState == ESetIccSmsStoreComplete)
+ {
+ iPhoneStoreInfo.iName = iStoreName;
+ Complete();
+ iPhoneGlobals.iEventSignalActive = EFalse;
+ iCtsyDispatcherCallback.CallbackPhonebookGetPhoneStoreInfoComp(iError,iPhoneStoreInfo);
+ }
+ }
+ }
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::GetPhoneStoreInfo
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::GetPhoneStoreInfo()
+ {
+ LOGTEXT(_L8("CAtPhbkGetPhoneStoreInfo::GetPhoneStoreInfo callded"));
+ iPhoneGlobals.iEventSignalActive = ETrue;
+ iTxBuffer.Zero();
+ iTxBuffer.Copy(KGetPhoneStoreInfo);
+ Write();
+ }
+
+// ---------------------------------------------------------------------------
+// CAtPhbkGetPhoneStoreInfo::ParseResponseL
+// other items were commented in a header
+// ---------------------------------------------------------------------------
+void CAtPhbkGetPhoneStoreInfo::ParseResponseL(const TDesC8& /*aResponseBuf*/)
+ {
+ if( iState == ESetPhoneStoreComplete )
+ {
+ if (CurrentLine().Match(KLtsyOkString) == 0)
+ {
+ iError = KErrNone;
+ }
+ else
+ {
+ iError = KErrGeneral;
+ }
+ }
+ else if( iState == EGetPhoneStoreInfoComplete )
+ {
+ /**
+ * Here is an Example
+ * +CPBS: "SM",6,250
+ * ADN phonebook is selected,6 locations are used and
+ * total 250 locations are available
+ */
+ iError = KErrNone;
+ RArray<TPtrC8> array;
+ CleanupClosePushL(array);
+ iParser->ParseRespondedBuffer(array,Buffer());
+ //remove AT+CPBS
+ if(array[0].MatchF(KAnyATCommand) != KErrNotFound)
+ {
+ array.Remove(0);
+ }
+ TInt count = array.Count();
+#ifdef _DEBUG
+ for( TInt i=0;i<count;i++ )
+ {
+ LOGTEXT3(_L8("CAtPhbkGetPhoneStoreInfo::ParseResponseL\tarray[%d]=%S"),
+ i,&array[i]);
+ }
+#endif
+ if (count <= 1)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = KErrNotFound;
+ return;
+ }
+ if(array[0].MatchF(KCPBSResponseString) == KErrNotFound)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = KErrNotFound;
+ return;
+ }
+
+ //parse used
+ TLex8 lex(array[2]);
+ TUint16 val;
+ TInt ret = lex.Val(val,EDecimal);
+ if(ret != KErrNone)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = ret;
+ return;
+ }
+ iPhoneStoreInfo.iUsedEntries = val;
+
+ //parse total
+ TLex8 lex1(array[3]);
+ ret = lex1.Val(val,EDecimal);
+ if(ret != KErrNone)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = ret;
+ return;
+ }
+ iPhoneStoreInfo.iTotalEntries = val;
+ iPhoneStoreInfo.iType = RMobilePhoneStore::EPhoneBookStore;
+ LOGTEXT3(_L8("CAtPhbkGetPhoneStoreInfo::ParseResponseL\tPreferred store used=%d, total=%d"),
+ iPhoneStoreInfo.iUsedEntries,iPhoneStoreInfo.iTotalEntries);
+ CleanupStack::PopAndDestroy(&array);
+ }
+ else
+ {
+ /**
+ * Parse result of AT+CPMS?
+ * Response:+CPMS:<mem1>,<used1>,<total1>,<mem2>,<used2>,<total2>
+ * Here only the first mem is used. mem1 is SM
+ */
+ iError = KErrNone;
+ RArray<TPtrC8> array;
+ CleanupClosePushL(array);
+ iParser->ParseRespondedBuffer(array,Buffer());
+ if(array[0].MatchF(KAnyATCommand) != KErrNotFound)
+ {
+ array.Remove(0);
+ }
+ TInt Count = array.Count();
+ if (Count <= 1)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = KErrNotFound;
+ return;
+ }
+ if(array[0].MatchF(KCPMSResponseString) == KErrNotFound)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = KErrNotFound;
+ return;
+ }
+ //parse name
+ TPtrC8 name(array[1]);
+
+ //parse used
+ TLex8 lex(array[2]);
+ TUint16 val;
+ TInt ret = lex.Val(val,EDecimal);
+ if(ret != KErrNone)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = ret;
+ return;
+ }
+ iPhoneStoreInfo.iUsedEntries = val;
+
+ //parse total
+ TLex8 lex1(array[3]);
+ ret = lex1.Val(val,EDecimal);
+ if(ret != KErrNone)
+ {
+ CleanupStack::PopAndDestroy();
+ iError = ret;
+ return;
+ }
+ iPhoneStoreInfo.iTotalEntries = val;
+ iPhoneStoreInfo.iType = RMobilePhoneStore::EShortMessageStore;
+ LOGTEXT3(_L8("CAtPhbkGetPhoneStoreInfo::ParseResponseL\tPreferred store used=%d, total=%d"),
+ iPhoneStoreInfo.iUsedEntries,iPhoneStoreInfo.iTotalEntries);
+ CleanupStack::PopAndDestroy(&array);
+ }
+ }
+
+//End of file