cbsref/telephonyrefplugins/atltsy/atcommand/generic/src/respondbufparser.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
// This contains CRespondBufParser which provide an algorithm to analize the passed data from baseband
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    15
//
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    16
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    17
#include "respondbufparser.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    18
#include "mslogger.h"
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    19
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    20
_LIT8(KSpace, " ");
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    21
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    22
CRespondBufParser::CRespondBufParser() 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    23
	{	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    24
	}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    25
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    26
CRespondBufParser::~CRespondBufParser()
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    27
	{
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
// CRespondBufParser::ParseRespondedBuffer
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
void CRespondBufParser::ParseRespondedBuffer(RArray<TPtrC8>& aArray, const TDesC8& aBuf)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    35
	{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    36
	aArray.Reset();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    37
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    38
	TBool firstDoubleQuoteFound = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    39
	TBool endByComma = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    40
	TBool Marked = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    41
	TLex8 tmpLex(aBuf);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    42
	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    43
	//Move cursor past any spaces or open brackets
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    44
	while(!tmpLex.Eos())
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    45
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    46
		TChar peek=tmpLex.Peek();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    47
		switch(peek)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    48
			{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    49
			//Skip the '(','[', and '{' in end
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    50
			case '(':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    51
			case '[':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    52
			case '{':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    53
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    54
			//Skip the '(','[', and '{' in end
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    55
			case ')':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    56
			case ']':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    57
			case '}':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    58
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    59
			case '"': 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    60
				//Skip first '"'
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    61
				if(!firstDoubleQuoteFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    62
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    63
					firstDoubleQuoteFound = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    64
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    65
				else
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    66
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    67
					//Extracts the marked token(No include the '"' in end)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    68
					firstDoubleQuoteFound = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    69
					TPtrC8 temp = tmpLex.MarkedToken();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    70
					aArray.Append(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    71
					LOGTEXT2(_L8("normal parameter >%S<"),&(temp));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    72
					Marked = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    73
					endByComma = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    74
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    75
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    76
			case ',':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    77
				if(!firstDoubleQuoteFound)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    78
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    79
					if(Marked)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    80
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    81
						//Extracts the marked token
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    82
						TPtrC8 temp = tmpLex.MarkedToken();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    83
						aArray.Append(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    84
						LOGTEXT2(_L8("normal parameter >%S<"),&(temp));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    85
						Marked = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    86
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    87
					else if(endByComma)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    88
						{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    89
						//Add a space between two camma
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    90
						aArray.Append(KSpace());
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    91
						LOGTEXT2(_L8("normal parameter >%S<"),&(KSpace()));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    92
						}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    93
					endByComma = ETrue;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    94
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    95
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    96
			case ';':
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    97
			case ' ': 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    98
			case '\r': 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
    99
			case '\n': 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   100
				if(!firstDoubleQuoteFound&&Marked)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   101
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   102
					//Extracts the marked token
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   103
					TPtrC8 temp = tmpLex.MarkedToken();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   104
					aArray.Append(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   105
					LOGTEXT2(_L8("normal parameter >%S<"),&(temp));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   106
					Marked = EFalse;	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   107
					endByComma = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   108
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   109
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   110
			case ':': 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   111
				if(!firstDoubleQuoteFound&&Marked)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   112
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   113
					//Extracts the marked token(Include ':')
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   114
					tmpLex.Inc();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   115
					TPtrC8 temp = tmpLex.MarkedToken();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   116
					aArray.Append(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   117
					LOGTEXT2(_L8("normal parameter >%S<"),&(temp));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   118
					//back one char because add it in end 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   119
					tmpLex.Inc(-1);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   120
					Marked = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   121
					endByComma = EFalse;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   122
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   123
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   124
			default:
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   125
				if(!Marked)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   126
					{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   127
					tmpLex.Mark();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   128
					Marked = ETrue;	
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   129
					}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   130
				break;
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   131
			}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   132
		tmpLex.Inc();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   133
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   134
	if(Marked)
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   135
		{
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   136
		//Extracts the marked token which haven't 
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   137
		TPtrC8 temp = tmpLex.MarkedToken();
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   138
		aArray.Append(temp);
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   139
		LOGTEXT2(_L8("normal parameter >%S<"),&(temp));
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   140
		}
8b72faa1200f 201024_02
hgs
parents:
diff changeset
   141
	}