/*
-* Copyright 2012-2013 Samsung Electronics Co., Ltd
-*
-* Licensed under the Flora License, Version 1.0 (the "License");
-* you may not use this file except in compliance with the License.
-* You may obtain a copy of the License at
-*
-* http://www.tizenopensource.org/license
-*
-* Unless required by applicable law or agreed to in writing, software
-* distributed under the License is distributed on an "AS IS" BASIS,
-* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-* See the License for the specific language governing permissions and
-* limitations under the License.
+ * Copyright (c) 2014 Samsung Electronics Co., Ltd. All rights reserved
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
*/
#include "VTypes.h"
#define CHECK_START 1
#define CHECK_END 2
-#define VFREE(obj) if(obj != NULL) { /*VDATA_TRACE("%p",obj);*/ free(obj); \
+#define VFREE(obj) if (obj != NULL) { /*VDATA_TRACE("%p",obj);*/ free(obj); \
obj = NULL; \
}
-#define TRIM(obj) if(obj != NULL) {\
+#define TRIM(obj) if (obj != NULL) {\
_VRLSpace(obj);\
_VRTSpace(obj);\
}
-#define UPPER(obj,start,end) if(obj != NULL) {\
- for(start = 0; start < end; start++)\
+#define UPPER(obj, start, end) if (obj != NULL) {\
+ for (start = 0; start < end; start++)\
obj[start] = toupper(obj[start]);\
}
#define SET_PARAM_VALUE(PARAM, SZVALUE, LIST, LISTCNT, PARAMOBJ, PTYPE, ENC) {\
PARAM = 0;\
PARAM |= __VMsgGetValue(SZVALUE, LIST, LISTCNT);\
- if ( PARAM != UNKNOWN_NAME ) {\
+ if (PARAM != UNKNOWN_NAME) {\
PARAMOBJ->parameter = PTYPE;\
- if(PTYPE == VMSG_PARAM_ENCODING)\
+ if (PTYPE == VMSG_PARAM_ENCODING)\
ENC = PARAM;\
break;\
- }\
+ } \
}
-#define LENGTH_TYPE_LIST(obj, len) for(len =0; obj[len] != NULL; len++);
+#define LENGTH_TYPE_LIST(obj, len) for (len = 0; obj[len] != NULL; len++);
-extern char* _VUnfoldingNoSpecNew( char *string );
+extern char* _VUnfoldingNoSpecNew(char *string);
/** GLOBAL VARIABLE DECLARATION AND INITIALIZATION */
/** vMsg Types. */
-char* pszMsgTypeList[] =
-{
+char* pszMsgTypeList[] = {
"BEGIN",
"END",
"TEL",
};
/** Parameter */
-char* pszMsgParamList[] =
-{
+char* pszMsgParamList[] = {
"CHARSET",
"CONTEXT",
"ENCODING",
};
/** Encoding value */
-ValueObj pMsgEncList[] =
-{
+ValueObj pMsgEncList[] = {
{"B", 0x00000001},
{"BASE64", 0x00000002},
{"QUOTED-PRINTABLE", 0x00000004},
};
/** Character set value */
-ValueObj pMsgCharsetList[] =
-{
+ValueObj pMsgCharsetList[] = {
{"UTF-8", 0x00000001},
{"UTF-16", 0x00000002},
{"ISO-8859-1", 0x00000004}
};
/** Value value */
-ValueObj pMsgValueList[] =
-{
+ValueObj pMsgValueList[] = {
{"BINARY", 0x00000001},
{"BOOLEAN", 0x00000002},
{"DATE", 0x00000004},
};
/** Type value */
-ValueObj pMsgTypeList[] =
-{
+ValueObj pMsgTypeList[] = {
{"AIFF", 0x00000001},
{"BBS", 0x00000002},
{"CAR", 0x00000004},
int __VMsgGetTypeName(char*, int*, int*);
int __VMsgGetParamName(char*, int*, int*);
int __VIsVmsgFile(char*, int);
-char* __VMsgGetParamVal(char*,int*, int*);
+char* __VMsgGetParamVal(char*, int*, int*);
char* __VMsgGetTypeVal(char*, int*, int*, int, VObject*);
char* __VMsgTypeEncode(VObject*, char*);
char* __VMsgParamEncode(VObject*, int*);
/**
* __VMsgGetName() compares the string and vMsg type, parameter name.
*
- * @param szString Name which will compare
+ * @param szString Name which will compare
* @param pszList[] Name list of vMsg type and param
- * @param size Number of total element of list
+ * @param size Number of total element of list
*
- * @return index The index in the list
+ * @return index The index in the list
*/
int
__VMsgGetName(char* szString, char* pszList[], int size)
low = 0;
high = size - 1;
- for(; high >= low; diff<0 ? (low = i+1):(high = i-1)) {
- i = ( low + high ) / 2;
- if((diff = strcmp( pszList[i], szString )) == 0) /* success: found it */
+ for (; high >= low; diff < 0 ? (low = i+1) : (high = i-1)) {
+ i = (low + high) / 2;
+ if ((diff = strcmp(pszList[i], szString)) == 0) /* success: found it */
return i;
}
VDATA_TRACE_END
/**
* __VMsgGetValue() compares the string and vMsg type, parameter value.
*
- * @param szString Value which will compare
+ * @param szString Value which will compare
* @param list[] Value list of vMsg param
- * @param size Number of total element of list
+ * @param size Number of total element of list
*
- * @return flag The value's flag.
+ * @return flag The value's flag.
*/
int
-__VMsgGetValue( char* szString, const ValueObj list[], int size)
+__VMsgGetValue(char* szString, const ValueObj list[], int size)
{
VDATA_TRACE_BEGINE
int i = 0, diff = -1;
SysRequireEx(szString, UNKNOWN_NAME);
SysRequireEx(size > 0, UNKNOWN_NAME);
- UPPER(szTemp,i,strlen(szTemp));
-
- for(i = 0; i < size-1; i++)
- {
- VDATA_TRACE(" i : %d",i);
- VDATA_TRACE(" for loop %d < %d, list[%d] : %p, list[%d].szName : %p",i,size,i,list[i],i,list[i].szName);
- VDATA_TRACE(" i : %d",i);
- if(list[i].szName != NULL)
- {
- VDATA_TRACE(" list[%d].szName != NULL",i);
- VDATA_TRACE(" before strcmp %s %s",list[i].szName,szTemp);
- VDATA_TRACE(" before strcmp %d",strcmp(list[i].szName, szTemp));
- if((diff = strcmp(list[i].szName, szTemp)) == 0) /* success: found it */
- {
- VDATA_TRACE(" return %d",list[i].flag);
+ UPPER(szTemp, i, strlen(szTemp));
+
+ for (i = 0; i < size-1; i++) {
+ VDATA_TRACE(" i : %d", i);
+ VDATA_TRACE(" for loop %d < %d, list[%d] : %p, list[%d].szName : %p", i, size, i, list[i], i, list[i].szName);
+ VDATA_TRACE(" i : %d", i);
+ if (list[i].szName != NULL) {
+ VDATA_TRACE(" list[%d].szName != NULL", i);
+ VDATA_TRACE(" before strcmp %s %s", list[i].szName, szTemp);
+ VDATA_TRACE(" before strcmp %d", strcmp(list[i].szName, szTemp));
+ if ((diff = strcmp(list[i].szName, szTemp)) == 0) { /* success: found it */
+ VDATA_TRACE(" return %d", list[i].flag);
VDATA_TRACE_END
return list[i].flag;
}
- VDATA_TRACE(" after strcmp %s %s",list[i].szName,szTemp);
+ VDATA_TRACE(" after strcmp %s %s", list[i].szName, szTemp);
}
}
VDATA_TRACE(" return UNKNOWN_NAME");
* __VMsgGetTypeName() fine the type name and returns the index number
*
* @param pVMsgRaw The raw data
- * @param pStatus Decoder status
+ * @param pStatus Decoder status
* @param pDLen retrived length
*
- * @return res The index in type list
+ * @return res The index in type list
*/
int
__VMsgGetTypeName(char* pVMsgRaw, int* pStatus, int* pDLen)
VDATA_TRACE_BEGINE
int i, index, res;
char c;
- char name[MAX_TYPE_NAME_LEN+1]={0,};
+ char name[MAX_TYPE_NAME_LEN+1] = {0,};
SysRequireEx(pVMsgRaw, UNKNOWN_NAME);
i = index = 0;
res = UNKNOWN_NAME;
- while(true) {
+ while (true) {
GO_NEXT_CHAR(c, pVMsgRaw, pDLen);
* If TYPE NAME's value is over MAX_TYPE_NAME_LEN, return UNKNOWN_NAME.
* And then Decoding Step shoud not be changed.
*/
- if(index >= MAX_TYPE_NAME_LEN) {
+ if (index >= MAX_TYPE_NAME_LEN) {
*pStatus = VMSG_TYPE_NAME_STATUS;
res = UNKNOWN_NAME;
break;
* If VTYPE_TOKEN_SEMICOLON or VTYPE_TOKEN_COLON is faced with,
* find TYPE NAME's value in pszMsgTypeList, and then return searched result.
*/
- if ((c == VTYPE_TOKEN_SEMICOLON ) || ( c == VTYPE_TOKEN_COLON)) {
+ if ((c == VTYPE_TOKEN_SEMICOLON) || (c == VTYPE_TOKEN_COLON)) {
name[index] = 0x00;
TRIM(name);
- UPPER(name,i,index);
- res = __VMsgGetName( name, (char**)pszMsgTypeList, VMSG_TYPE_NUM );
+ UPPER(name, i, index);
+ res = __VMsgGetName(name, (char**)pszMsgTypeList, VMSG_TYPE_NUM);
break;
}
/**
* There is no new line in TYPE NAME.
* If new line character is faced with, return UNKNOWN_NAME;
*/
- else if ( ( c == '\r' ) || ( c == '\n' ) )
- {
+ else if ((c == '\r') || (c == '\n')) {
(*pDLen)++;
*pStatus = VMSG_TYPE_NAME_STATUS;
res = UNKNOWN_NAME;
return res;
- }
- else if(_VIsSpace(c));
- else name[index++] = c;
+ } else if (_VIsSpace(c)) {
+ } else
+ name[index++] = c;
}
/**
* Set Next Step.
*
*/
- if ( c == VTYPE_TOKEN_SEMICOLON )
+ if (c == VTYPE_TOKEN_SEMICOLON)
/**
* This case next token is parameter. So set VMSG_PARAM_NAME_STATUS step.
*/
*pStatus = VMSG_PARAM_NAME_STATUS;
- else
- {
- if(res != UNKNOWN_NAME)
+ else {
+ if (res != UNKNOWN_NAME)
/**
* This case next string is value. So set VMSG_TYPE_VALUE_STATUS step.
*/
* __VMsgGetParamName() fine the param name and returns the index number
*
* @param pVMsgRaw The raw data
- * @param pStatus Decoder status
+ * @param pStatus Decoder status
* @param pDLen retrived length
*
- * @return res The index in type list
+ * @return res The index in type list
*/
int
-__VMsgGetParamName( char* pVMsgRaw, int* pStatus, int* pDLen )
+__VMsgGetParamName(char* pVMsgRaw, int* pStatus, int* pDLen)
{
VDATA_TRACE_BEGINE
int i, index, res;
char c;
- char name[MAX_PARAM_NAME_LEN+1]={0,};
+ char name[MAX_PARAM_NAME_LEN+1] = {0,};
char* pTemp = pVMsgRaw;
- SysRequireEx( pVMsgRaw, UNKNOWN_NAME );
+ SysRequireEx(pVMsgRaw, UNKNOWN_NAME);
i = index = 0;
res = UNKNOWN_NAME;
- while ( true )
- {
+ while (true) {
GO_NEXT_CHAR(c, pVMsgRaw, pDLen);
/**
* If PARAM NAME's value is over MAX_PARAM_NAME_LEN, return UNKNOWN_NAME.
* And then Decoding Step shoud not be changed.
*/
- if(index >= MAX_PARAM_NAME_LEN) {
+ if (index >= MAX_PARAM_NAME_LEN) {
*pStatus = VMSG_TYPE_NAME_STATUS;
res = UNKNOWN_NAME;
break;
* If VTYPE_TOKEN_EQUAL is faced with,
* find PARAM NAME's value in pszMsgParamList, and then return searched result.
*/
- if(c == VTYPE_TOKEN_EQUAL) {
+ if (c == VTYPE_TOKEN_EQUAL) {
name[index] = '\0';
TRIM(name);
UPPER(name, i, index);
- res = __VMsgGetName( name, ( char** )pszMsgParamList, VMSG_PARAM_NUM );
- if(res==UNKNOWN_NAME){
+ res = __VMsgGetName(name, (char**)pszMsgParamList, VMSG_PARAM_NUM);
+ if (res == UNKNOWN_NAME)
(*pDLen) = 0;
- }
*pStatus = VMSG_PARAM_VALUE_STATUS;
break;
}
* VMSG_PARAM_NAME_STATUS(current) -> VMSG_PARAM_VALUE_STATUS
* -> VMSG_TYPE_VALUE_STATUS -> MOVE TO NEXT TYPE
*/
- else if(c == VTYPE_TOKEN_COLON) {
+ else if (c == VTYPE_TOKEN_COLON) {
*pStatus = VMSG_PARAM_VALUE_STATUS;
pVMsgRaw = pTemp;
(*pDLen) = 0;
* VMSG_PARAM_NAME_STATUS(current) -> VMSG_PARAM_NAME_STATUS
* -> VMSG_PARAM_VALUE_STATUS -> VMSG_TYPE_VALUE_STATUS -> MOVE TO NEXT TYPE
*/
- else if(c == VTYPE_TOKEN_SEMICOLON) {
+ else if (c == VTYPE_TOKEN_SEMICOLON) {
*pStatus = VMSG_PARAM_NAME_STATUS;
pVMsgRaw = pTemp;
(*pDLen) = 0;
res = UNKNOWN_NAME;
break;
- }
- else if((c == '\r') || (c == '\n') || (_VIsSpace(c)));
- else
+ } else if ((c == '\r') || (c == '\n') || (_VIsSpace(c))) {
+
+ } else
name[index++] = c;
}
VDATA_TRACE_END
int count = 0;
int i = 0;
- SysRequireEx( pTree->treeType == VMESSAGE, false );
- SysRequireEx( pTree != NULL, false );
+ SysRequireEx(pTree->treeType == VMESSAGE, false);
+ SysRequireEx(pTree != NULL, false);
VDATA_TRACE("vmsg_free_vtree_memory() entered.");
- if (pTree->treeType != VMESSAGE)
- {
+ if (pTree->treeType != VMESSAGE) {
VDATA_TRACE_END
return true;
}
pCurTree = pTree;
- while(pCurTree)
- {
+ while (pCurTree) {
pNextTree = pCurTree->pNext;
pCurObj = pCurTree->pTop;
- while ( pCurObj )
- {
+ while (pCurObj) {
pNextObj = pCurObj->pSibling;
count = pCurObj->valueCount;
- for ( i = 0; i < count; i++ ) {
- VFREE( pCurObj->pszValue[i]);
- }
+ for (i = 0; i < count; i++)
+ VFREE(pCurObj->pszValue[i]);
- if ( pCurObj->pParam )
- {
+ if (pCurObj->pParam) {
pCurParam = pCurObj->pParam;
- while(pCurParam != NULL)
- {
+ while (pCurParam != NULL) {
pNextParam = pCurParam->pNext;
VDATA_TRACE("pNEXT ==> %p", pCurParam->pNext);
VDATA_TRACE("pPARAM ==> %p", pCurParam->parameter);
VDATA_TRACE("pCurParam : %p", pCurParam);
VDATA_TRACE("pCurParam->parameter : %d", pCurParam->parameter);
VDATA_TRACE("pCurParam->paramValue : %d", pCurParam->paramValue);
- if(pNextParam != NULL) {
+ if (pNextParam != NULL) {
VDATA_TRACE("pNextParam : %p", pNextParam);
VDATA_TRACE("pNextParam->parameter : %d", pNextParam->parameter);
VDATA_TRACE("pNextParam->paramValue : %d", pNextParam->paramValue);
}
}
- VFREE( pCurObj );
+ VFREE(pCurObj);
pCurObj = pNextObj;
}
- VFREE( pCurTree );
+ VFREE(pCurTree);
pCurTree = pNextTree;
}
* __VMsgGetParamVal() fine the param value and returns value.
*
* @param pVMsgRaw The raw data
- * @param pStatus Decoder status
+ * @param pStatus Decoder status
* @param pDLen retrived length
*
- * @return buffer The result value
+ * @return buffer The result value
*/
char*
-__VMsgGetParamVal( char* pVMsgRaw, int* pStatus, int* pDLen )
+__VMsgGetParamVal(char* pVMsgRaw, int* pStatus, int* pDLen)
{
VDATA_TRACE_BEGINE
int len = 0;
char* pBuf = NULL;
char* pTemp = pVMsgRaw;
- SysRequireEx( pVMsgRaw, NULL );
+ SysRequireEx(pVMsgRaw, NULL);
- while(true) {
+ while (true) {
GO_NEXT_CHAR(c, pVMsgRaw, pDLen);
len++;
- switch(c) {
- case VTYPE_TOKEN_SEMICOLON :
- *pStatus = VMSG_PARAM_NAME_STATUS;
- break;
- case VTYPE_TOKEN_COLON :
- *pStatus = VMSG_TYPE_VALUE_STATUS;
- break;
- case VTYPE_TOKEN_COMMA :
- *pStatus = VMSG_PARAM_VALUE_STATUS;
- break;
+ switch (c) {
+ case VTYPE_TOKEN_SEMICOLON:
+ *pStatus = VMSG_PARAM_NAME_STATUS;
+ break;
+ case VTYPE_TOKEN_COLON:
+ *pStatus = VMSG_TYPE_VALUE_STATUS;
+ break;
+ case VTYPE_TOKEN_COMMA:
+ *pStatus = VMSG_PARAM_VALUE_STATUS;
+ break;
}
- if( c == VTYPE_TOKEN_SEMICOLON
+ if (c == VTYPE_TOKEN_SEMICOLON
|| c == VTYPE_TOKEN_COLON
|| c == VTYPE_TOKEN_COMMA
|| c == 0x00)
break;
}
- if(len < 1 || (pBuf = (char *)malloc(len)) == NULL)
+ if (len < 1 || (pBuf = (char *)calloc(1, len)) == NULL)
return NULL;
memset(pBuf, 0x00, len);
- memcpy( pBuf, pTemp, len-1 );
+ memcpy(pBuf, pTemp, len-1);
TRIM(pBuf);
VDATA_TRACE_END
return pBuf;
/**
* __VMsgGetTypeVal() fine the type value and returns value.
*
- * @param pVMsgRaw The raw data
+ * @param pVMsgRaw The raw data
* @param status Decoder status
- * @return buffer The result value
+ * @return buffer The result value
*/
char*
-__VMsgGetTypeVal( char* pVMsgRaw, int* pStatus, int* pDLen, int enc, VObject* pType)
+__VMsgGetTypeVal(char* pVMsgRaw, int* pStatus, int* pDLen, int enc, VObject* pType)
{
VDATA_TRACE_BEGINE
int num = 0;
int Status = 0;
int Len = 0;
- SysRequireEx( pVMsgRaw, NULL );
+ SysRequireEx(pVMsgRaw, NULL);
VDATA_TRACE("pVMsgRaw: %s", pVMsgRaw);
- while(true)
- {
+ while (true) {
GO_NEXT_CHAR(c, pVMsgRaw, pDLen);
- if( c == 0x00)
+ if (c == 0x00)
break;
len++;
/** This case means that there are more type's value. */
- if ( c == VTYPE_TOKEN_SEMICOLON && bEscape == false )
- {
- if((pBuf = (char *)malloc(len)) == NULL)
+ if (c == VTYPE_TOKEN_SEMICOLON && bEscape == false) {
+ if ((pBuf = (char *)calloc(1, len)) == NULL)
return NULL;
memset(pBuf, 0x00, len);
- memcpy(pBuf,pTemp,len-1);
+ memcpy(pBuf, pTemp, len-1);
TRIM(pBuf);
_VUnescape(pBuf);
*pStatus = VMSG_TYPE_VALUE_STATUS;
/** Base 64 Decoding */
- if((enc & pMsgEncList[1].flag) || (enc & pMsgEncList[0].flag))
- {
+ if ((enc & pMsgEncList[1].flag) || (enc & pMsgEncList[0].flag)) {
bufferCount = (len * 6 / 8) + 2;
- if((pTmpBuf = (char *)malloc(bufferCount)) == NULL)
- {
+ if ((pTmpBuf = (char *)calloc(1, bufferCount)) == NULL) {
VFREE(pBuf);
return NULL;
}
memset(pTmpBuf, 0x00, bufferCount);
num = _VB64Decode(pTmpBuf, pBuf);
- if(pType != NULL)
+ if (pType != NULL)
pType->numOfBiData = num;
VFREE(pBuf);
}
/** Quoted Printable Decoding */
- if(enc & pMsgEncList[2].flag)
- {
+ if (enc & pMsgEncList[2].flag) {
int i = 0, j = 0;
- while(pBuf[i])
- {
- if(pBuf[i] == '\n' || pBuf[i] == '\r')
- {
+ while (pBuf[i]) {
+ if (pBuf[i] == '\n' || pBuf[i] == '\r') {
i++;
- if(pBuf[i] == '\n'|| pBuf[i] == '\r')
+ if (pBuf[i] == '\n' || pBuf[i] == '\r')
i++;
- if(pBuf[j-1] == '=')
+ if (pBuf[j-1] == '=')
j--;
- }
- else
+ } else
pBuf[j++] = pBuf[i++];
}
pBuf[j] = '\0';
break;
}
- if(c == '\\')
+ if (c == '\\')
bEscape = true;
- else if(bEscape == true && c != VTYPE_TOKEN_SEMICOLON )
+ else if (bEscape == true && c != VTYPE_TOKEN_SEMICOLON)
bEscape = false;
- else if((c == '\r') || (c == '\n'))
- {
+ else if ((c == '\r') || (c == '\n')) {
c2 = *(pVMsgRaw-2);
- if(c2 == '=' && (enc & pMsgEncList[2].flag))
- {
+ if (c2 == '=' && (enc & pMsgEncList[2].flag)) {
c1 = *pVMsgRaw;
- if((c1 == '\r') || (c1 == '\n'))
- {
+ if ((c1 == '\r') || (c1 == '\n')) {
pVMsgRaw += 1;
(*pDLen) += 1;
len++;
}
- }
- else if(__VMsgGetTypeName(pVMsgRaw, &Status, &Len) != UNKNOWN_NAME)
- {
- if((pBuf = (char *)malloc(len)) == NULL)
+ } else if (__VMsgGetTypeName(pVMsgRaw, &Status, &Len) != UNKNOWN_NAME) {
+ if ((pBuf = (char *)calloc(1, len)) == NULL)
return NULL;
memset(pBuf, 0x00, len);
c1 = *pVMsgRaw;
- if((c1 == '\r') || (c1 == '\n'))
- {
+ if ((c1 == '\r') || (c1 == '\n')) {
pVMsgRaw += 1;
(*pDLen) += 1;
}
- if((enc & pMsgEncList[1].flag) || (enc & pMsgEncList[0].flag))
- {
+ if ((enc & pMsgEncList[1].flag) || (enc & pMsgEncList[0].flag)) {
bufferCount = (len * 6 / 8) + 5;
- if((pTmpBuf = (char *)malloc(bufferCount)) == NULL)
- {
+ if ((pTmpBuf = (char *)calloc(1, bufferCount)) == NULL) {
VFREE(pBuf);
return NULL;
}
memset(pTmpBuf, 0x00, bufferCount);
num = _VB64Decode(pTmpBuf, pBuf);
- if(pType != NULL)
+ if (pType != NULL)
pType->numOfBiData = num;
VFREE(pBuf);
break;
}
- if(enc & pMsgEncList[2].flag)
- {
+ if (enc & pMsgEncList[2].flag) {
int i = 0, j = 0;
- while(pBuf[i])
- {
- if(pBuf[i] == '\n' || pBuf[i] == '\r')
- {
+ while (pBuf[i]) {
+ if (pBuf[i] == '\n' || pBuf[i] == '\r') {
i++;
- if(pBuf[i] == '\n' || pBuf[i] == '\r')
+ if (pBuf[i] == '\n' || pBuf[i] == '\r')
i++;
- if(pBuf[j-1] == '=') j--;
- }
- else
+ if (pBuf[j-1] == '=') j--;
+ } else
pBuf[j++] = pBuf[i++];
}
pBuf[j] = '\0';
int
-VMsgGetTypeValue( int index )
+VMsgGetTypeValue(int index)
{
VDATA_TRACE_BEGINE
VDATA_TRACE("VMsgGetTypeValue() enter..\n");
}
int
-VMsgGetValValue( int index )
+VMsgGetValValue(int index)
{
VDATA_TRACE_BEGINE
VDATA_TRACE("VMsgGetValValue() enter..\n");
}
int
-VMsgGetEncValue( int index )
+VMsgGetEncValue(int index)
{
VDATA_TRACE_BEGINE
VDATA_TRACE("VMsgGetEncValue() enter..\n");
}
int
-VMsgGetCharsetValue( int index )
+VMsgGetCharsetValue(int index)
{
VDATA_TRACE_BEGINE
VDATA_TRACE("VMsgGetCharsetValue() enter..\n");
* @param pVMsgRaw The raw data
* @return vObject The result value
*/
-SLPAPI VTree*
-vmsg_decode( char *pMsgRaw )
+VTree* vmsg_decode(char *pMsgRaw)
{
VDATA_TRACE_BEGINE;
int param_status = false;
int numberedParam = 0;
int enc = 0;
- int start_status = 0;
char* temp = NULL;
char* pVTree = NULL;
bool vmsg_ended = false;
SysRequireEx(pMsgRaw != NULL, NULL);
len = strlen(pMsgRaw);
+ VDATA_TRACE("length of pCardRaw = %d", len);
+
len = _VUnfoldingNoSpec(pMsgRaw, VMESSAGE);
pMsgRawTmp = pMsgRaw;
- len = _VManySpace2Space( pMsgRaw );
+ len = _VManySpace2Space(pMsgRaw);
- if(!__VIsVmsgFile(pMsgRaw, CHECK_START)) {
+ VDATA_TRACE("ret value of _VManySpace2Space = %d", len);
+
+ if (!__VIsVmsgFile(pMsgRaw, CHECK_START)) {
VFREE(pMsgRawTmp);
VDATA_TRACE_END
return NULL;
}
- while(true && !done)
- {
+ while (true && !done) {
c = *pMsgRaw;
- if((c == '\0') || done)
+ if ((c == '\0') || done)
break;
- switch(status) {
- case VMSG_TYPE_NAME_STATUS:
- dLen = 0;
- type = __VMsgGetTypeName(pMsgRaw, &status, &dLen);
-
- if(type == VMSG_TYPE_BEGIN)
- pVTree = pMsgRaw;
-
- pMsgRaw += dLen;
-
- if(type == -1)
- break;
-
- switch ( type )
- {
- case VMSG_TYPE_BEGIN:
- dLen = 0;
- enc = 0;
- szMsgBegin = __VMsgGetTypeVal(pMsgRaw, &status, &dLen, enc, NULL);
- pMsgRaw += dLen;
-
- if(szMsgBegin == NULL)
- goto CATCH;
-
- if(!strncmp(szMsgBegin, "VCARD", strlen("VCARD")))
- {
- VDATA_TRACE("pVTree: %s", pVTree);
- pVCard = vcard_decode(pVTree);
- pCurrent->pNext = pVCard;
- pCurrent = pVCard;
+ switch (status) {
+ case VMSG_TYPE_NAME_STATUS:
+ dLen = 0;
+ type = __VMsgGetTypeName(pMsgRaw, &status, &dLen);
- dLen = ((strstr(pMsgRaw,"END:VCARD") + 9) - pMsgRaw);
- pMsgRaw += dLen;
- }
-
- else
- {
-
- if(start_status == 1)
- goto CATCH;
-
-
-
-
- if(!strncmp(szMsgBegin, "VMSG", strlen("VMSG")))
- {
- if ( ( pVMsg = ( VTree* )malloc( sizeof( VTree ) ) ) == NULL )
- {
- start_status = 1;
- goto CATCH;
- }
- memset(pVMsg,0x00, sizeof(VTree));
-
- pVMsg->treeType = VMESSAGE;
- pVMsg->pTop = NULL;
- pVMsg->pCur = NULL;
- pVMsg->pNext = NULL;
- pCurrent = pVMsg;
- }
-
- else if(!strncmp(szMsgBegin, "VBODY", strlen("VBODY")))
- {
- if ( ( pVBody = ( VTree* )malloc( sizeof( VTree ) ) ) == NULL )
- {
- start_status = 1;
- goto CATCH;
- }
-
- memset(pVBody,0x00, sizeof(VTree));
- pVBody->treeType = VBODY;
- pVBody->pTop = NULL;
- pVBody->pCur = NULL;
- pVBody->pNext = NULL;
- pCurrent->pNext = pVBody;
- pCurrent = pVBody;
- }
- }
+ if (type == VMSG_TYPE_BEGIN)
+ pVTree = pMsgRaw;
- VFREE(szMsgBegin);
- break;
+ pMsgRaw += dLen;
- case VMSG_TYPE_END:
- dLen = 0;
- enc = 0;
- //szMsgBegin = __VMsgGetTypeVal(pMsgRaw, &status, &dLen, enc, NULL);
+ if (type == -1)
+ break;
- if(!strncmp(pMsgRaw,"VMSG", strlen("VMSG")))
- {
- done = true;
- vmsg_ended = true;
- }
- else
- {
- status = VMSG_TYPE_NAME_STATUS;
- //pMsgRaw += dLen;
- }
- VDATA_TRACE("pMsgRaw:%s", pMsgRaw);
- pMsgRaw += dLen;
- break;
+ switch (type) {
+ case VMSG_TYPE_BEGIN:
+ dLen = 0;
+ enc = 0;
+ szMsgBegin = __VMsgGetTypeVal(pMsgRaw, &status, &dLen, enc, NULL);
+ pMsgRaw += dLen;
- case UNKNOWN_NAME :
- break;
+ if (szMsgBegin == NULL)
+ goto CATCH;
- default:
- if(UNKNOWN_NAME == type || type < 0) {
- status = VMSG_TYPE_NAME_STATUS;
- break;
- }
+ if (!strncmp(szMsgBegin, "VCARD", strlen("VCARD"))) {
+ VDATA_TRACE("pVTree: %s", pVTree);
+ pVCard = vcard_decode(pVTree);
+ if (pCurrent) {
+ pCurrent->pNext = pVCard;
+ }
+ pCurrent = pVCard;
- if ( ( pTemp = ( VObject* )malloc( sizeof( VObject ) ) ) == NULL )
- {
+ dLen = ((strstr(pMsgRaw, "END:VCARD") + 9) - pMsgRaw);
+ pMsgRaw += dLen;
+ } else {
+ if (!strncmp(szMsgBegin, "VMSG", strlen("VMSG"))) {
+ if ((pVMsg = (VTree*)calloc(1, sizeof(VTree))) == NULL) {
goto CATCH;
}
-
- memset( pTemp, 0, sizeof( VObject ) );
- pTemp->property = type;
-
- if ( pCurrent->pTop == NULL ) {
- pCurrent->pTop = pTemp;
- pCurrent->pCur = pTemp;
- }
- else {
- pCurrent->pCur->pSibling = pTemp;
- pCurrent->pCur = pTemp;
+ memset(pVMsg, 0x00, sizeof(VTree));
+
+ pVMsg->treeType = VMESSAGE;
+ pVMsg->pTop = NULL;
+ pVMsg->pCur = NULL;
+ pVMsg->pNext = NULL;
+ pCurrent = pVMsg;
+ } else if (!strncmp(szMsgBegin, "VBODY", strlen("VBODY"))) {
+ if ((pVBody = (VTree*)calloc(1, sizeof(VTree))) == NULL) {
+ goto CATCH;
}
- break;
+ memset(pVBody, 0x00, sizeof(VTree));
+ pVBody->treeType = VBODY;
+ pVBody->pTop = NULL;
+ pVBody->pCur = NULL;
+ pVBody->pNext = NULL;
+ if (pCurrent)
+ pCurrent->pNext = pVBody;
+ pCurrent = pVBody;
+ }
}
- numberedParam = 0;
- param_status = false;
- valueCount = 0;
+ VFREE(szMsgBegin);
break;
- case VMSG_PARAM_NAME_STATUS:
- {
+ case VMSG_TYPE_END:
dLen = 0;
- param = __VMsgGetParamName( pMsgRaw, &status, &dLen );
+ enc = 0;
+ /* szMsgBegin = __VMsgGetTypeVal(pMsgRaw, &status, &dLen, enc, NULL); */
+
+ if (!strncmp(pMsgRaw, "VMSG", strlen("VMSG"))) {
+ done = true;
+ vmsg_ended = true;
+ } else {
+ status = VMSG_TYPE_NAME_STATUS;
+ /* pMsgRaw += dLen; */
+ }
+ VDATA_TRACE("pMsgRaw:%s", pMsgRaw);
pMsgRaw += dLen;
+ break;
- if ( param_status != true ) {
-
- if ( ( pTmpParam = ( VParam* )malloc( sizeof( VParam ) ) ) == NULL )
- goto CATCH;
+ case UNKNOWN_NAME:
+ break;
- param_status = true;
- pCurrent->pCur->pParam = pTmpParam;
- memset( pTmpParam, 0x00, sizeof( VParam ) );
- VDATA_TRACE("pTmpParam : %p", pTmpParam);
+ default:
+ if (UNKNOWN_NAME == type || type < 0) {
+ status = VMSG_TYPE_NAME_STATUS;
+ break;
}
- else
- {
- if ( ( pTmpParam->pNext = ( VParam* )malloc( sizeof( VParam ) ) ) == NULL )
- goto CATCH;
- pTmpParam = pTmpParam->pNext;
- memset( pTmpParam, 0x00, sizeof(VParam));
- VDATA_TRACE("pTmpParam : %p", pTmpParam);
+ if ((pTemp = (VObject*)calloc(1, sizeof(VObject))) == NULL)
+ goto CATCH;
+
+ memset(pTemp, 0, sizeof(VObject));
+ pTemp->property = type;
+
+ if (pCurrent) {
+ if (pCurrent->pTop == NULL) {
+ pCurrent->pTop = pTemp;
+ pCurrent->pCur = pTemp;
+ } else {
+ pCurrent->pCur->pSibling = pTemp;
+ pCurrent->pCur = pTemp;
+ }
}
- pTmpParam->parameter = param;
break;
}
- case VMSG_PARAM_VALUE_STATUS:
- dLen = 0;
- numberedParam = 0;
- switch ( pTmpParam->parameter )
- {
- case VMSG_PARAM_TYPE:
- szValue = __VMsgGetParamVal( pMsgRaw, &status, &dLen );
- numberedParam |= __VMsgGetValue( szValue, pMsgTypeList, VMSG_TYPE_PARAM_NUM );
- break;
- case VMSG_PARAM_VALUE:
- szValue = __VMsgGetParamVal( pMsgRaw, &status, &dLen );
- numberedParam |= __VMsgGetValue( szValue, pMsgValueList, VMSG_VALUE_PARAM_NUM );
- break;
- case VMSG_PARAM_ENCODING:
- szValue = __VMsgGetParamVal( pMsgRaw, &status, &dLen );
- numberedParam |= __VMsgGetValue( szValue, pMsgEncList, VMSG_ENCODE_PARAM_NUM );
- enc = numberedParam;
- break;
- case VMSG_PARAM_CHARSET:
- szValue = __VMsgGetParamVal( pMsgRaw, &status, &dLen );
- numberedParam |= __VMsgGetValue( szValue, pMsgCharsetList, VMSG_CHARSET_PARAM_NUM );
- break;
- case VMSG_PARAM_CONTEXT:
- case VMSG_PARAM_LANGUAGE:
- // prevent 7605 08.03.13
- szValue = __VMsgGetParamVal( pMsgRaw, &status, &dLen );
- numberedParam = 0;
- break;
- default:
- szValue = __VMsgGetParamVal( pMsgRaw, &status, &dLen );
- SET_PARAM_VALUE(numberedParam, szValue, pMsgTypeList, VMSG_TYPE_PARAM_NUM, pTmpParam, VMSG_PARAM_TYPE, enc);
- SET_PARAM_VALUE(numberedParam, szValue, pMsgValueList, VMSG_VALUE_PARAM_NUM, pTmpParam, VMSG_PARAM_VALUE, enc);
- SET_PARAM_VALUE(numberedParam, szValue, pMsgEncList, VMSG_ENCODE_PARAM_NUM, pTmpParam, VMSG_PARAM_ENCODING, enc);
- SET_PARAM_VALUE(numberedParam, szValue, pMsgCharsetList, VMSG_CHARSET_PARAM_NUM, pTmpParam, VMSG_PARAM_CHARSET, enc);
+ numberedParam = 0;
+ param_status = false;
+ valueCount = 0;
+ break;
- numberedParam = 0;
- pMsgRaw += dLen;
- dLen = 0;
+ case VMSG_PARAM_NAME_STATUS:
+ {
+ dLen = 0;
+ param = __VMsgGetParamName(pMsgRaw, &status, &dLen);
+ pMsgRaw += dLen;
- break;
- }
+ if (param_status != true) {
- VDATA_TRACE("%d, %s, %p",numberedParam, szValue, pTmpParam);
- pTmpParam->paramValue = numberedParam;
- pTmpParam->pNext = NULL;
- VFREE(szValue);
- pMsgRaw += dLen;
+ if ((pTmpParam = (VParam*)calloc(1, sizeof(VParam))) == NULL)
+ goto CATCH;
+
+ param_status = true;
+ if (pCurrent)
+ pCurrent->pCur->pParam = pTmpParam;
+ memset(pTmpParam, 0x00, sizeof(VParam));
+ VDATA_TRACE("pTmpParam : %p", pTmpParam);
+ } else {
+ if ((pTmpParam->pNext = (VParam*)calloc(1, sizeof(VParam))) == NULL)
+ goto CATCH;
+
+ pTmpParam = pTmpParam->pNext;
+ memset(pTmpParam, 0x00, sizeof(VParam));
+ VDATA_TRACE("pTmpParam : %p", pTmpParam);
+ }
+
+ pTmpParam->parameter = param;
+ break;
+ }
+ case VMSG_PARAM_VALUE_STATUS:
+ dLen = 0;
+ numberedParam = 0;
+ switch (pTmpParam->parameter) {
+ case VMSG_PARAM_TYPE:
+ szValue = __VMsgGetParamVal(pMsgRaw, &status, &dLen);
+ numberedParam |= __VMsgGetValue(szValue, pMsgTypeList, VMSG_TYPE_PARAM_NUM);
break;
- case VMSG_TYPE_VALUE_STATUS:
- dLen = 0;
- temp = __VMsgGetTypeVal( pMsgRaw, &status, &dLen, enc, pCurrent->pCur);
+ case VMSG_PARAM_VALUE:
+ szValue = __VMsgGetParamVal(pMsgRaw, &status, &dLen);
+ numberedParam |= __VMsgGetValue(szValue, pMsgValueList, VMSG_VALUE_PARAM_NUM);
+ break;
+ case VMSG_PARAM_ENCODING:
+ szValue = __VMsgGetParamVal(pMsgRaw, &status, &dLen);
+ numberedParam |= __VMsgGetValue(szValue, pMsgEncList, VMSG_ENCODE_PARAM_NUM);
+ enc = numberedParam;
+ break;
+ case VMSG_PARAM_CHARSET:
+ szValue = __VMsgGetParamVal(pMsgRaw, &status, &dLen);
+ numberedParam |= __VMsgGetValue(szValue, pMsgCharsetList, VMSG_CHARSET_PARAM_NUM);
+ break;
+ case VMSG_PARAM_CONTEXT:
+ case VMSG_PARAM_LANGUAGE:
+ /* prevent 7605 08.03.13 */
+ szValue = __VMsgGetParamVal(pMsgRaw, &status, &dLen);
+ numberedParam = 0;
+ break;
+ default:
+ szValue = __VMsgGetParamVal(pMsgRaw, &status, &dLen);
- if(valueCount <= VDATA_VALUE_COUNT_MAX) {
- pCurrent->pCur->pszValue[valueCount] = temp;
- valueCount++;
- pCurrent->pCur->valueCount = valueCount;
- VDATA_TRACE("object property: %d, value: %s", pCurrent->pCur->property, pCurrent->pCur->pszValue[valueCount - 1]);
- }
- else
- VFREE(temp);
+ SET_PARAM_VALUE(numberedParam, szValue, pMsgTypeList, VMSG_TYPE_PARAM_NUM, pTmpParam, VMSG_PARAM_TYPE, enc);
+ SET_PARAM_VALUE(numberedParam, szValue, pMsgValueList, VMSG_VALUE_PARAM_NUM, pTmpParam, VMSG_PARAM_VALUE, enc);
+ SET_PARAM_VALUE(numberedParam, szValue, pMsgEncList, VMSG_ENCODE_PARAM_NUM, pTmpParam, VMSG_PARAM_ENCODING, enc);
+ SET_PARAM_VALUE(numberedParam, szValue, pMsgCharsetList, VMSG_CHARSET_PARAM_NUM, pTmpParam, VMSG_PARAM_CHARSET, enc);
+ numberedParam = 0;
pMsgRaw += dLen;
+ dLen = 0;
+
break;
+ }
+
+ VDATA_TRACE("%d, %s, %p", numberedParam, szValue, pTmpParam);
+ pTmpParam->paramValue = numberedParam;
+ pTmpParam->pNext = NULL;
+ VFREE(szValue);
+ pMsgRaw += dLen;
+ break;
+ case VMSG_TYPE_VALUE_STATUS:
+ dLen = 0;
+ temp = __VMsgGetTypeVal(pMsgRaw, &status, &dLen, enc, pCurrent->pCur);
+
+ if (valueCount < VDATA_VALUE_COUNT_MAX) {
+ pCurrent->pCur->pszValue[valueCount] = temp;
+ valueCount++;
+ pCurrent->pCur->valueCount = valueCount;
+ VDATA_TRACE("object property: %d, value: %s", pCurrent->pCur->property, pCurrent->pCur->pszValue[valueCount - 1]);
+ } else
+ VFREE(temp);
+
+ pMsgRaw += dLen;
+ break;
}
}
VDATA_TRACE("pMsgRawTmp: %s", pMsgRawTmp);
- //VFREE(pMsgRawTmp);
+ /* VFREE(pMsgRawTmp); */
- if(pVMsg->pTop == NULL)
- {
+ if (pVMsg && pVMsg->pTop == NULL) {
VDATA_TRACE("pVMsg->Top: NULL");
goto CATCH;
}
- if(!vmsg_ended) {
+ if (!vmsg_ended) {
VDATA_TRACE("vmsg_ended: false");
goto CATCH1;
}
VDATA_TRACE_END
+ VFREE(pTemp);
+ VFREE(pTmpParam);
+ VFREE(pVBody);
return pVMsg;
-CATCH :
+CATCH:
+ VFREE(pTemp);
+CATCH1:
VFREE(pTemp);
-CATCH1 :
+ VFREE(szMsgBegin);
VFREE(pMsgRawTmp);
- __VMsgFreeVTreeMemory(pVMsg);
+ VFREE(pTmpParam);
+ VFREE(pVBody);
+ vmsg_free_vtree_memory(pVMsg);
VDATA_TRACE_END
return NULL;
}
* @param pVMsgRaw Data which will be encoded
* @return char * Encoded result
*/
-SLPAPI char*
-vmsg_encode( VTree *pVMsgRaw )
+char* vmsg_encode(VTree *pVMsgRaw)
{
VDATA_TRACE_BEGINE
char* pVMsgRes = NULL;
char* pTemp = NULL;
int len;
int total = 0;
- int cnt = 0;
+ int cnt = 0;
- for(;cnt < pVMsgRaw->pTop->valueCount;cnt++) {
+ if (!pVMsgRaw || !pVMsgRaw->pTop) {
+ return NULL;
+ }
+
+ for (; cnt < pVMsgRaw->pTop->valueCount; cnt++) {
- if(pVMsgRaw->pTop->pszValue[cnt] == NULL) {
- VDATA_TRACE("pVMsgRaw->pTop->valueCount : %d",pVMsgRaw->pTop->valueCount);
+ if (pVMsgRaw->pTop->pszValue[cnt] == NULL) {
+ VDATA_TRACE("pVMsgRaw->pTop->valueCount : %d", pVMsgRaw->pTop->valueCount);
VDATA_TRACE("pVMsgRaw->pTop->pszValue[%d] : %s", cnt, pVMsgRaw->pTop->pszValue[cnt]);
VDATA_TRACE_END
return NULL;
pTmpTree = pVMsgRaw;
pTmpObj = pVMsgRaw->pTop;
- while(true)
- {
- switch(pTmpTree->treeType)
- {
- case VMESSAGE:
- if (pVMsgRes) {
- free(pVMsgRes);
- pVMsgRes = NULL;
- }
+ while (true) {
+ switch (pTmpTree->treeType) {
+ case VMESSAGE:
+ if (pVMsgRes) {
+ free(pVMsgRes);
+ pVMsgRes = NULL;
+ }
- if ( ( pVMsgRes = ( char * )malloc( sizeof( char ) * ( total += 13 ) ) ) == NULL )
- {
- VDATA_TRACE( "vmsg_encode:malloc failed\n" );
- VDATA_TRACE_END
- return NULL;
- }
- memcpy( pVMsgRes, "BEGIN:VMSG\r\n", 13 );
- break;
+ if ((pVMsgRes = (char *)calloc(1, sizeof(char) * (total += 13))) == NULL) {
+ VDATA_TRACE("vmsg_encode:calloc failed\n");
+ VDATA_TRACE_END
+ return NULL;
+ }
+ memcpy(pVMsgRes, "BEGIN:VMSG\r\n", 13);
+ break;
- case VBODY:
- if ( ( pTmpVMsgRes = ( char * )realloc( pVMsgRes, sizeof( char ) * ( total += 14 ) ) ) == NULL )
- {
- VDATA_TRACE( "vmsg_encode:realloc failed\n" );
- VFREE(pVMsgRes);
- VDATA_TRACE_END
- return NULL;
- }
+ case VBODY:
+ if ((pTmpVMsgRes = (char *)realloc(pVMsgRes, sizeof(char) * (total += 14))) == NULL) {
+ VDATA_TRACE("vmsg_encode:realloc failed\n");
+ VFREE(pVMsgRes);
+ VDATA_TRACE_END
+ return NULL;
+ }
- pVMsgRes = pTmpVMsgRes;
- strncat( pVMsgRes, "BEGIN:VBODY\r\n", 13);
- break;
+ pVMsgRes = pTmpVMsgRes;
+ g_strlcat(pVMsgRes, "BEGIN:VBODY\r\n", 13);
+ break;
- case VCARD:
- break;
+ case VCARD:
+ break;
}
- while ( true )
- {
- if(pTmpObj == NULL)
+ while (true) {
+ if (pTmpObj == NULL)
break;
- if ( ( pTemp = __VMsgTypeEncode( pTmpObj, pTmpObj->property == VCARD_TYPE_TEL ? "TEL" : pszMsgTypeList[pTmpObj->property] ) ) != NULL )
- {
- if(pTmpTree->treeType == VCARD)
- {
+ if ((pTemp = __VMsgTypeEncode(pTmpObj, pTmpObj->property == VCARD_TYPE_TEL ? "TEL" : pszMsgTypeList[pTmpObj->property])) != NULL) {
+ if (pTmpTree->treeType == VCARD) {
char* encoded = NULL;
encoded = vcard_encode(pTmpTree);
if (encoded == NULL) {
- VDATA_TRACE( "vcard_encode() failed\n");
+ VDATA_TRACE("vcard_encode() failed\n");
VFREE(pTemp);
VFREE(pVMsgRes);
VDATA_TRACE_END
return NULL;
}
- len= strlen(encoded);
+ len = strlen(encoded);
- if ( ( pTmpVMsgRes = ( char* )realloc( pVMsgRes, ( total += len+10 ) ) ) == NULL )
- {
- VDATA_TRACE( "vmsg_encode():realloc failed\n");
- VFREE( pTemp );
- VFREE( encoded );
+ if ((pTmpVMsgRes = (char*)realloc(pVMsgRes, (total += len+10))) == NULL) {
+ VDATA_TRACE("vmsg_encode():realloc failed\n");
+ VFREE(pTemp);
+ VFREE(encoded);
VFREE(pVMsgRes);
VDATA_TRACE_END
return NULL;
}
pVMsgRes = pTmpVMsgRes;
- strncat(pVMsgRes, encoded, len+10);
+ g_strlcat(pVMsgRes, encoded, len+10);
VDATA_TRACE("pTemp : %s", encoded);
- VFREE( pTemp );
- VFREE( encoded );
- VFREE(pVMsgRes);
+ VFREE(pTemp);
+ VFREE(encoded);
break;
- }
- else
- {
- len = strlen( pTemp );
-
- if ( ( pTmpVMsgRes = ( char* )realloc( pVMsgRes, ( total += len+10 ) ) ) == NULL )
- {
- VDATA_TRACE( "vmsg_encode():realloc failed\n");
- VFREE( pTemp );
+ } else {
+ len = strlen(pTemp);
+
+ if ((pTmpVMsgRes = (char*)realloc(pVMsgRes, (total += len+10))) == NULL) {
+ VDATA_TRACE("vmsg_encode():realloc failed\n");
+ VFREE(pTemp);
VFREE(pVMsgRes);
VDATA_TRACE_END
return NULL;
}
pVMsgRes = pTmpVMsgRes;
- strncat(pVMsgRes, pTemp, len+10);
+ g_strlcat(pVMsgRes, pTemp, len+10);
VDATA_TRACE("pTemp : %s", pTemp);
- VFREE( pTemp );
+ VFREE(pTemp);
- if ( pTmpObj->pSibling != NULL )
+ if (pTmpObj->pSibling != NULL)
pTmpObj = pTmpObj->pSibling;
else
break;
}
}
-
-
}
- switch(pTmpTree->treeType)
- {
- case VBODY:
- if ( ( pTmpVMsgRes = ( char * )realloc( pVMsgRes, ( total += 12 ) ) ) == NULL )
- {
- VFREE(pVMsgRes);
- VDATA_TRACE( "vcal_encode():realloc failed\n");
- return NULL;
- }
+ switch (pTmpTree->treeType) {
+ case VBODY:
+ if ((pTmpVMsgRes = (char *)realloc(pVMsgRes, (total += 12))) == NULL) {
+ VFREE(pVMsgRes);
+ VDATA_TRACE("vcal_encode():realloc failed\n");
+ return NULL;
+ }
- pVMsgRes = pTmpVMsgRes;
- strncat( pVMsgRes, "END:VBODY\r\n", 12);
- break;
+ pVMsgRes = pTmpVMsgRes;
+ g_strlcat(pVMsgRes, "END:VBODY\r\n", 12);
+ break;
- case VCARD:
- break;
+ case VCARD:
+ break;
- case VMESSAGE:
- break;
+ case VMESSAGE:
+ break;
}
- if ( pTmpTree->pNext != NULL )
+ if (pTmpTree->pNext != NULL)
pTmpTree = pTmpTree->pNext;
else
break;
pTmpObj = pTmpTree->pTop;
}
- if ( ( pTmpVMsgRes = ( char * )realloc( pVMsgRes, ( total += 11 ) ) ) == NULL )
- {
- VDATA_TRACE( "vmsg_encode:realloc failed\n");
+ if ((pTmpVMsgRes = (char *)realloc(pVMsgRes, (total += 11))) == NULL) {
+ VDATA_TRACE("vmsg_encode:realloc failed\n");
VFREE(pVMsgRes);
VDATA_TRACE_END
return NULL;
}
pVMsgRes = pTmpVMsgRes;
- strncat( pVMsgRes, "END:VMSG\r\n", 11);
+ g_strlcat(pVMsgRes, "END:VMSG\r\n", 11);
VDATA_TRACE_END
return pVMsgRes;
}
int
__VIsVmsgFile(char *pMsgRaw, int mode)
{
- int i=0;
+ int i = 0;
bool rtnValue = true;
char *pszVmsgBegin = "BEGIN:VMSG";
- switch(mode)
- {
- case CHECK_START :
- for(i=0; i < 10; i++)
- if(*pszVmsgBegin++ != *pMsgRaw++)
- rtnValue = false;
- break;
+ switch (mode) {
+ case CHECK_START:
+ for (i = 0; i < 10; i++)
+ if (*pszVmsgBegin++ != *pMsgRaw++)
+ rtnValue = false;
+ break;
- default :
- rtnValue = false;
+ default:
+ rtnValue = false;
}
VDATA_TRACE_END
return rtnValue;
* @return char * Encoded result
*/
char*
-__VMsgTypeEncode( VObject *pTypeObj, char *pType )
+__VMsgTypeEncode(VObject *pTypeObj, char *pType)
{
VDATA_TRACE_BEGINE
int len;
char* pTemp = NULL;
char* szTypeValue = NULL;
+ char* szTemp = NULL;
int i;
int enc = 0;
char* pEncode = NULL;
int total = 0;
int biLen = 0;
- len = strlen( pType );
+ len = strlen(pType);
biLen = pTypeObj->numOfBiData;
- if ( ( szTypeValue = ( char * )malloc( total += ( len+1 ) ) ) == NULL )
- {
- VDATA_TRACE( "__VMsgTypeEncode():malloc failed\n");
+ if ((szTypeValue = (char *)calloc(1, total += (len+1))) == NULL) {
+ VDATA_TRACE("__VMsgTypeEncode():calloc failed\n");
VDATA_TRACE_END
return NULL;
}
- memset( szTypeValue, '\0', ( len+1 ) );
- strncat( szTypeValue, pType, len+1);
-
- pTemp = __VMsgParamEncode( pTypeObj, &enc );
- if ( pTemp != NULL )
- {
- len = strlen( pTemp );
- if ( ( szTypeValue = ( char * )realloc( szTypeValue, ( total += len ) ) ) == NULL )
- {
- VDATA_TRACE( "__VMsgTypeEncode():realloc failed\n");
- VFREE( pTemp );
- pTemp = NULL
- VDATA_TRACE_END;
+ memset(szTypeValue, '\0', (len+1));
+ g_strlcat(szTypeValue, pType, len+1);
+
+ pTemp = __VMsgParamEncode(pTypeObj, &enc);
+ if (pTemp != NULL) {
+ len = strlen(pTemp);
+ if ((szTemp = (char *)realloc(szTypeValue, (total += len))) == NULL) {
+ VDATA_TRACE("__VMsgTypeEncode():realloc failed\n");
+ VFREE(pTemp);
+ pTemp = NULL;
+ VFREE(szTypeValue);
+ VDATA_TRACE_END
return NULL;
+ } else {
+ szTypeValue = szTemp;
}
- strncat( szTypeValue, pTemp, len);
- VFREE( pTemp );
+ g_strlcat(szTypeValue, pTemp, len);
+ VFREE(pTemp);
pTemp = NULL;
}
- if ( ( szTypeValue = ( char * )realloc( szTypeValue, ( total += 2 ) ) ) == NULL )
- {
+ if ((szTemp = (char *)realloc(szTypeValue, (total += 2))) == NULL) {
+ VFREE(szTypeValue);
VDATA_TRACE_END
return NULL;
+ } else {
+ szTypeValue = szTemp;
}
- strncat( szTypeValue, ":", 2 );
+ g_strlcat(szTypeValue, ":", 2);
len = 0;
- if(strcmp(pType, pszMsgTypeList[6]) != 0) {
- for ( i = 0; i < pTypeObj->valueCount; i++ ) {
+ if (strcmp(pType, pszMsgTypeList[6]) != 0) {
+ for (i = 0; i < pTypeObj->valueCount; i++) {
- if(pTypeObj->pszValue[i] != NULL)
- len += strlen( pTypeObj->pszValue[i] );
- }
- }
- else
+ if (pTypeObj->pszValue[i] != NULL)
+ len += strlen(pTypeObj->pszValue[i]);
+ }
+ } else
len += biLen;
- for ( i = 0; i < pTypeObj->valueCount; i++ ) {
+ for (i = 0; i < pTypeObj->valueCount; i++) {
- if ( i == 0 )
- {
- if ( ( pEncode = ( char * )malloc( len+20 ) ) == NULL )
- {
+ if (i == 0) {
+ if ((pEncode = (char *)calloc(1, len+20)) == NULL) {
VFREE(szTypeValue);
VDATA_TRACE_END
return NULL;
}
- memset( pEncode, '\0', len+20 );
+ memset(pEncode, '\0', len+20);
- if(strcmp(pType, pszMsgTypeList[6]) != 0)
- {
- strncat( pEncode, pTypeObj->pszValue[i], 20 );
+ if (strcmp(pType, pszMsgTypeList[6]) != 0) {
+ g_strlcat(pEncode, pTypeObj->pszValue[i], 20);
_VEscape(pEncode);
- }
- else
+ } else
memcpy(pEncode, pTypeObj->pszValue[i], biLen);
- }
- else
- {
+ } else {
char buf[1000];
- strncpy( buf, pTypeObj->pszValue[i], 999 );
- _VEscape( buf );
- strcat( pEncode, ";" );
- strcat( pEncode, buf );
+ strncpy(buf, pTypeObj->pszValue[i], 999);
+ _VEscape(buf);
+ g_strlcat(pEncode, ";" , len+20);
+ g_strlcat(pEncode, buf , len+20);
}
}
- if(strcmp(pType, pszMsgTypeList[6]) != 0) {
+ if (strcmp(pType, pszMsgTypeList[6]) != 0) {
if (pEncode) {
- strcat( pEncode, "\0\0" );
- len = strlen( pEncode );
+ g_strlcat(pEncode, "\0\0", 2);
+ len = strlen(pEncode);
}
- }
- else {
+ } else {
len = biLen;
}
- if ( enc & pMsgEncList[2].flag ) {
- if((pRes = (char *)malloc(len * 6 + 10)) == NULL) {
+ if (enc & pMsgEncList[2].flag) {
+ if ((pRes = (char *)calloc(1, len * 6 + 10)) == NULL) {
VFREE(pEncode);
VFREE(szTypeValue);
VDATA_TRACE_END
return NULL;
}
- if(pEncode)
- _VQPEncode( pRes, pEncode );
+ if (pEncode)
+ _VQPEncode(pRes, pEncode);
VFREE(pEncode);
- }
- else if(enc & pMsgEncList[1].flag )
- {
- if((pRes = (char *)malloc((len * 8 / 6) + 48)) == NULL)
- {
+ } else if (enc & pMsgEncList[1].flag) {
+ if ((pRes = (char *)calloc(1, (len * 8 / 6) + 48)) == NULL) {
VFREE(pEncode);
VFREE(szTypeValue);
VDATA_TRACE_END
return NULL;
}
- memset( pRes, '\0', ( ( len * 8 / 6 ) + 48 ) );
- _VB64Encode( pRes, pEncode, biLen );
- VDATA_TRACE( "Origin Size: %d, Allocated Size %d, Coverted Size: %d\n", biLen, ( len * 8 / 6 ) + 48, strlen(pRes));
+ memset(pRes, '\0', ((len * 8 / 6) + 48));
+ _VB64Encode(pRes, pEncode, biLen);
+ VDATA_TRACE("Origin Size: %d, Allocated Size %d, Coverted Size: %d\n", biLen, (len * 8 / 6) + 48, strlen(pRes));
VFREE(pEncode);
- }
- else
- {
- if((pRes = (char *)malloc(len+30)) == NULL)
- {
+ } else {
+ if ((pRes = (char *)calloc(1, len+30)) == NULL) {
VFREE(pEncode);
VFREE(szTypeValue);
VDATA_TRACE_END
return NULL;
}
- memset( pRes, '\0', ( len + 30 ) );
- if(pEncode)
- {
- memcpy( pRes, pEncode, len );
+ memset(pRes, '\0', (len + 30));
+ if (pEncode) {
+ memcpy(pRes, pEncode, len);
VFREE(pEncode);
}
}
- if((pRes = (char *)realloc(pRes, strlen(pRes) + 3)) == NULL)
- {
+ if ((szTemp = (char *)realloc(pRes, strlen(pRes) + 3)) == NULL) {
VFREE(pEncode);
VFREE(szTypeValue);
+ VFREE(pRes);
VDATA_TRACE_END
return NULL;
+ } else {
+ pRes = szTemp;
}
- strncat( pRes, "\r\n", strlen(pRes) + 2);
+ g_strlcat(pRes, "\r\n", strlen(pRes) + 2);
- len = strlen( pRes );
+ len = strlen(pRes);
- if ((szTypeValue = (char *)realloc(szTypeValue, (total += (len+3)))) == NULL) {
+ if ((szTemp = (char *)realloc(szTypeValue, (total += (len+3)))) == NULL) {
VFREE(pEncode);
VFREE(pRes);
+ VFREE(szTypeValue);
VDATA_TRACE_END
return NULL;
+ } else {
+ szTypeValue = szTemp;
}
- strncat(szTypeValue, pRes, total - 1);
+ g_strlcat(szTypeValue, pRes, total - 1);
- if(strcmp(pType, pszMsgTypeList[6]) != 0) {
- _VRLSpace( szTypeValue );
- _VRTSpace( szTypeValue );
+ if (strcmp(pType, pszMsgTypeList[6]) != 0) {
+ _VRLSpace(szTypeValue);
+ _VRTSpace(szTypeValue);
}
VFREE(pRes);
int shift = 0;
bool bSupported;
char* szParam = NULL;
+ char* szTemp = NULL;
VParam* pTemp = NULL;
ValueObj* pList = NULL;
pTemp = pTypeObj->pParam;
/** Momory Allocation for parameter string. */
- if(pTemp != NULL) {
- if ((szParam = (char*)malloc(len+=2)) == NULL)
- {
+ if (pTemp != NULL) {
+ if ((szParam = (char*)calloc(1, len += 2)) == NULL) {
VDATA_TRACE_END
return NULL;
}
}
/** appending pamaters. */
- while(true) {
+ while (true) {
- if(pTemp == NULL) break;
+ if (pTemp == NULL) break;
bSupported = false;
/** Expand szParam string. For appending.*/
- if((szParam = (char *)realloc(szParam, len += 15)) == NULL)
- {
+ if ((szTemp = (char *)realloc(szParam, len += 15)) == NULL) {
+ VFREE(szParam);
VDATA_TRACE_END
return NULL;
+ } else {
+ szParam = szTemp;
}
/** appending paramter name. */
- strcat( szParam, ";" );
- if(pTemp->parameter != VMSG_PARAM_TYPE) {
- strcat( szParam, pszMsgParamList[pTemp->parameter] );
- strcat( szParam, "=" );
+ g_strlcat(szParam, ";" , len);
+ if (pTemp->parameter != VMSG_PARAM_TYPE) {
+ g_strlcat(szParam, pszMsgParamList[pTemp->parameter], len);
+ g_strlcat(szParam, "=", len);
}
/** Set Parameter Value name. */
- switch ( pTemp->parameter )
- {
- case VMSG_PARAM_ENCODING:
- *pEnc = pMsgEncList[pTemp->paramValue].flag;
- shift = VMSG_ENCODE_PARAM_NUM;
- pList = pMsgEncList; bSupported = true;
- break;
- case VMSG_PARAM_TYPE:
- shift = VMSG_TYPE_PARAM_NUM;
- pList = pMsgTypeList; bSupported = true;
- break;
- case VMSG_PARAM_VALUE:
- shift = VMSG_VALUE_PARAM_NUM;
- pList = pMsgValueList; bSupported = true;
- break;
- case VMSG_PARAM_CHARSET:
- shift = VMSG_CHARSET_PARAM_NUM;
- pList = pMsgCharsetList; bSupported = true;
- break;
- default:
- if ( ( szParam = ( char* )realloc( szParam, 5 ) ) == NULL )
- {
- VDATA_TRACE_END
- return NULL;
- }
- strcat( szParam, "NONE" );
+ switch (pTemp->parameter) {
+ case VMSG_PARAM_ENCODING:
+ *pEnc = pMsgEncList[pTemp->paramValue].flag;
+ shift = VMSG_ENCODE_PARAM_NUM;
+ pList = pMsgEncList; bSupported = true;
+ break;
+ case VMSG_PARAM_TYPE:
+ shift = VMSG_TYPE_PARAM_NUM;
+ pList = pMsgTypeList; bSupported = true;
+ break;
+ case VMSG_PARAM_VALUE:
+ shift = VMSG_VALUE_PARAM_NUM;
+ pList = pMsgValueList; bSupported = true;
+ break;
+ case VMSG_PARAM_CHARSET:
+ shift = VMSG_CHARSET_PARAM_NUM;
+ pList = pMsgCharsetList; bSupported = true;
+ break;
+ default:
+ if ((szTemp = (char*)realloc(szParam, 5)) == NULL) {
+ VFREE(szParam);
+ VDATA_TRACE_END
+ return NULL;
+ } else {
+ szParam = szTemp;
+ }
+ g_strlcat(szParam, "NONE", strlen("NONE"));
}
/** exchage parameter value's to string.*/
- if(bSupported == true) {
+ if (bSupported == true) {
- for(i = 0, sNum = 0x00000001; i < shift; i++) {
+ for (i = 0, sNum = 0x00000001; i < shift; i++) {
- if(pList[pTemp->paramValue].flag & sNum) {
- if((szParam = (char *)realloc(szParam, ( len += (strlen(pList[i].szName) + 2)))) == NULL)
- {
+ if (pList[pTemp->paramValue].flag & sNum) {
+ if ((szTemp = (char *)realloc(szParam, (len += (strlen(pList[i].szName) + 2)))) == NULL) {
+ VFREE(szParam);
VDATA_TRACE_END
return NULL;
+ } else {
+ szParam = szTemp;
}
- strcat( szParam, pList[i].szName );
- strcat( szParam, "; " );
+ g_strlcat(szParam, pList[i].szName, len);
+ g_strlcat(szParam, "; ", len);
}
sNum <<= 1;
}
/** remove semicolon from tail. */
- for(i = strlen( szParam ); i > 0 ; i--) {
+ for (i = strlen(szParam); i > 0 ; i--) {
- if ( szParam[i] == ' ' && szParam[i-1] == ';' ) {
+ if (szParam[i] == ' ' && szParam[i-1] == ';') {
szParam[i-1] = '\0';
break;
}
}
- if ( pTemp->pNext != NULL )
+ if (pTemp->pNext != NULL)
pTemp = pTemp->pNext;
else
break;
return szParam;
}
-SLPAPI bool
+bool
vmsg_free_vtree_memory(VTree * pTree)
{
VDATA_TRACE_BEGINE
- if(pTree == NULL)
- {
+ if (pTree == NULL) {
VDATA_TRACE_END
return false;
}