2 * Copyright (c) 2014 Samsung Electronics Co., Ltd. All rights reserved
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
21 #define MAX_TYPE_NAME_LEN 50
22 #define MAX_PARAM_NAME_LEN 50
26 #define VFREE(obj) if(obj != NULL) { /*VDATA_TRACE("%p",obj);*/ free(obj); \
30 #define TRIM(obj) if(obj != NULL) {\
35 #define UPPER(obj,start,end) if(obj != NULL) {\
36 for(start = 0; start < end; start++)\
37 obj[start] = toupper(obj[start]);\
40 #define GO_NEXT_CHAR(current, rowData, addedCnt) {\
46 #define SET_PARAM_VALUE(PARAM, SZVALUE, LIST, LISTCNT, PARAMOBJ, PTYPE, ENC) {\
48 PARAM |= __VCardGetValue(SZVALUE, LIST, LISTCNT);\
49 if ( PARAM != UNKNOWN_NAME ) {\
50 PARAMOBJ->parameter = PTYPE;\
51 if(PTYPE == VCARD_PARAM_ENCODING)\
57 #define LENGTH_TYPE_LIST(obj, len) for(len =0; obj[len] != NULL; len++);
59 extern char* _VUnfoldingNoSpecNew( char *string );
61 /** GLOBAL VARIABLE DECLARATION AND INITIALIZATION */
63 char* pszCardTypeList[] =
65 "ADR", /* Delivery Address -> address*/
66 "AGENT", /* Agent -> assistant name, assistant number*/
67 "BDAY", /* Birthday -> birthday */
68 "BEGIN", /* BEGIN VCARD DELIMITER*/
69 "CATEGORIES", /* Categories is a multivalued attribute */
71 "EMAIL", /* Email -> email */
72 "END", /* END VCARD DELIMITER*/
73 "FN", /* Formatted Name -> display_name */
74 "GEO", /* Geographic Positioning*/
75 "KEY", /* Public Key*/
76 "LABEL", /* Label Address -> address*/
78 "MAILER", /* Email Program (Optional)*/
79 "N", /* Name -> name */
80 "NAME", /* Name -> name */
81 "NICKNAME", /* Nickname -> nickname */
82 "NOTE", /* Note -> note */
83 "ORG", /* Organization Name or Organizational unit -> department*/
84 "PHOTO", /* Photograph -> caller id*/
87 "REV", /* Last Revision(combination of calendar date & time)*/
88 "ROLE", /* Role or occupation */
92 "TEL", /* Telephone -> phone number */
93 "TITLE", /* Job Title -> job title */
95 "UID", /* Unique Identifier*/
96 "URL", /* URL -> web address */
97 "VERSION", /* Version*/
103 char* pszCardParamList[] =
113 /** Encoding value */
114 ValueObj pEncList[] =
117 {"BASE64", 0x00000002},
118 {"QUOTED-PRINTABLE", 0x00000004},
119 {"7BIT", 0x00000008},
123 /** Character set value */
124 ValueObj pCharsetList[] =
126 {"UTF-8", 0x00000001},
127 {"UTF-16", 0x00000002},
128 {"ISO-8859-1", 0x00000004}
132 ValueObj pValueList[] =
134 {"BINARY", 0x00000001},
135 {"BOOLEAN", 0x00000002},
136 {"DATE", 0x00000004},
137 {"DATE-TIME", 0x00000008},
138 {"FLOAT", 0x00000010},
139 {"INTEGER", 0x00000020},
140 {"PHONE-NUMBER", 0x00000040},
141 {"TEXT", 0x00000080},
142 {"TIME", 0x00000100},
145 {"UTC-OFFSET", 0x00000800},
146 {"VCARD", 0x00001000}
150 ValueObj pTypeList[] =
152 {"AIFF", 0x00000001},
155 {"CELL", 0x00000008},
157 {"WORK", 0x00000020},
160 {"HOME", 0x00000100},
161 {"INTL", 0x00000200},
162 {"INTERNET", 0x00000400},
163 {"ISDN", 0x00000800},
164 {"JPEG", 0x00001000},
165 {"MOBILE", 0x00002000},
166 {"MODEM", 0x00004000},
168 {"PAGER", 0x00010000},
169 {"PARCEL", 0x00020000},
173 {"POSTAL", 0x00200000},
174 {"PREF", 0x00400000},
175 {"VIDEO", 0x00800000},
176 {"VOICE", 0x01000000},
177 {"WAVE", 0x02000000},
178 {"WBMP", 0x04000000},
183 /** FUNCTION DECLARATION */
184 int __VCardGetName(char*, char**, int);
185 int __VCardGetValue(char*, const ValueObj*, int);
186 int __VCardGetTypeName(char*, int*, int*);
187 int __VCardGetParamName(char*, int*, int*);
188 int __VIsVcardFile(char*, int);
189 char* __VCardGetParamVal(char*,int*, int*);
190 char* __VCardGetTypeVal(char*, int*, int*, int, VObject*);
191 char* __VCardTypeEncode(VObject*, char*);
192 char* __VCardParamEncode(VObject*, int*);
194 #ifdef VDATA_GROUPNAME_SUPPORTED
196 #endif // VDATA_GROUPNAME_SUPPORTED
200 * __VCardGetName() compares the string and vCard type, parameter name.
202 * @param szString Name which will compare
203 * @param pszList[] Name list of vCard type and param
204 * @param size Number of total element of list
206 * @return index The index in the list
209 __VCardGetName(char* szString, char* pszList[], int size)
212 int high, low, i, diff;
217 for(; high >= low; diff<0 ? (low = i+1):(high = i-1)) {
218 i = ( low + high ) / 2;
219 if((diff = strcmp( pszList[i], szString )) == 0) /* success: found it */
227 * __VCardGetValue() compares the string and vCard type, parameter value.
229 * @param szString Value which will compare
230 * @param list[] Value list of vCard param
231 * @param size Number of total element of list
233 * @return flag The value's flag.
236 __VCardGetValue( char* szString, const ValueObj list[], int size)
239 int i = 0, diff = -1;
240 char* szTemp = szString;
242 SysRequireEx(szString, UNKNOWN_NAME);
243 SysRequireEx(size > 0, UNKNOWN_NAME);
245 UPPER(szTemp,i,strlen(szTemp));
247 for(i = 0; i < size-1; i++)
249 VDATA_TRACE(" i : %d",i);
250 VDATA_TRACE(" for loop %d < %d, list[%d] : %p, list[%d].szName : %p",i,size,i,list[i],i,list[i].szName);
251 VDATA_TRACE(" i : %d",i);
252 if(list[i].szName != NULL)
254 VDATA_TRACE(" list[%d].szName != NULL",i);
255 VDATA_TRACE(" before strcmp %s %s",list[i].szName,szTemp);
256 VDATA_TRACE(" before strcmp %d",strcmp(list[i].szName, szTemp));
257 if((diff = strcmp(list[i].szName, szTemp)) == 0) /* success: found it */
259 VDATA_TRACE(" return %d",list[i].flag);
263 VDATA_TRACE(" after strcmp %s %s",list[i].szName,szTemp);
266 VDATA_TRACE(" return UNKNOWN_NAME");
272 * __VCardGetTypeName() fine the type name and returns the index number
274 * @param pVCardRaw The raw data
275 * @param pStatus Decoder status
276 * @param pDLen retrived length
278 * @return res The index in type list
281 __VCardGetTypeName(char* pVCardRaw, int* pStatus, int* pDLen)
286 char name[MAX_TYPE_NAME_LEN+1]={0,};
288 #ifdef VDATA_GROUPNAME_SUPPORTED
289 char* szGroupName = NULL;
290 #endif // VDATA_GROUPNAME_SUPPORTED
292 SysRequireEx(pVCardRaw, UNKNOWN_NAME);
299 GO_NEXT_CHAR(c, pVCardRaw, pDLen);
302 * TYPE NAME's length is must be less than MAX_TYPE_NAME_LEN.
303 * If TYPE NAME's value is over MAX_TYPE_NAME_LEN, return UNKNOWN_NAME.
304 * And then Decoding Step shoud not be changed.
306 if(index >= MAX_TYPE_NAME_LEN) {
307 *pStatus = VCARD_TYPE_NAME_STATUS;
313 * There is a delimeter between TYPE NAME and next element(=Param, or Type Value).
314 * If VTYPE_TOKEN_SEMICOLON or VTYPE_TOKEN_COLON is faced with,
315 * find TYPE NAME's value in pszCardTypeList, and then return searched result.
317 if ((c == VTYPE_TOKEN_SEMICOLON ) || ( c == VTYPE_TOKEN_COLON)) {
321 res = __VCardGetName( name, (char**)pszCardTypeList, VCARD_TYPE_NUM );
324 /** current version not support grouping vcard type */
325 else if ( c == VTYPE_TOKEN_DOT ) {
326 #ifdef VDATA_GROUPNAME_SUPPORTED
328 szGroupName = ( char* ) malloc ( index+1 );
329 if(szGroupName != NULL){
330 strncpy( szGroupName, name, index );
331 gszGroupName = szGroupName;
337 * There is no new line in TYPE NAME.
338 * If new line character is faced with, return UNKNOWN_NAME;
340 else if ( ( c == '\r' ) || ( c == '\n' ) )
343 *pStatus = VCARD_TYPE_NAME_STATUS;
347 else if(_VIsSpace(c));
348 else name[index++] = c;
355 if ( c == VTYPE_TOKEN_SEMICOLON )
357 * This case next token is parameter. So set VCARD_PARAM_NAME_STATUS step.
359 *pStatus = VCARD_PARAM_NAME_STATUS;
361 if(res != UNKNOWN_NAME)
363 * This case next string is value. So set VCARD_TYPE_VALUE_STATUS step.
365 *pStatus = VCARD_TYPE_VALUE_STATUS;
368 * In current step, TYPE NAME is invalid. So Try to get TYPE NAME again from next position.
370 *pStatus = VCARD_TYPE_NAME_STATUS;
377 * __VCardGetParamName() fine the param name and returns the index number
379 * @param pVCardRaw The raw data
380 * @param pStatus Decoder status
381 * @param pDLen retrived length
383 * @return res The index in type list
386 __VCardGetParamName( char* pVCardRaw, int* pStatus, int* pDLen )
392 char name[MAX_PARAM_NAME_LEN+1]={0,};
393 char* pTemp = pVCardRaw;
395 SysRequireEx( pVCardRaw, UNKNOWN_NAME );
402 GO_NEXT_CHAR(c, pVCardRaw, pDLen);
405 * PARAM NAME's length is must be less than MAX_PARAM_NAME_LEN.
406 * If PARAM NAME's value is over MAX_PARAM_NAME_LEN, return UNKNOWN_NAME.
407 * And then Decoding Step shoud not be changed.
409 if(index >= MAX_PARAM_NAME_LEN) {
410 *pStatus = VCARD_TYPE_NAME_STATUS;
416 * There is a delimeter between PARAM NAME and next element(=Param, or Param Value).
417 * If VTYPE_TOKEN_EQUAL is faced with,
418 * find PARAM NAME's value in pszCardParamList, and then return searched result.
420 if(c == VTYPE_TOKEN_EQUAL) {
423 UPPER(name, i, index);
424 res = __VCardGetName( name, ( char** )pszCardParamList, VCARD_PARAM_NUM );
425 if(res==UNKNOWN_NAME){
428 *pStatus = VCARD_PARAM_VALUE_STATUS;
432 * This case, There is no parameter type. Only Parameter Value.
433 * In VCARD_PARAM_NAME_STATUS status, VTYPE_TOKEN_COLON means that anything parameter is no more.
434 * so set next step to VCARD_PARAM_VALUE_STATUS.
436 * Ex) TEL;WORK:+12341234
437 * ------ ":" next is TEL TYPE's value.
439 * VCARD_PARAM_NAME_STATUS(current) -> VCARD_PARAM_VALUE_STATUS
440 * -> VCARD_TYPE_VALUE_STATUS -> MOVE TO NEXT TYPE
442 else if(c == VTYPE_TOKEN_COLON) {
443 *pStatus = VCARD_PARAM_VALUE_STATUS;
450 * This case, There is no parameter type. Only Parameter Value.
451 * In VCARD_PARAM_NAME_STATUS status, VTYPE_TOKEN_SEMICOLON means that there is a next parameter.
452 * so set next step to VCARD_PARAM_NAME_STATUS.
454 * Ex) TEL;WORK;PREF:+12341234
455 * ------ ":" next is TEL TYPE's value.
457 * VCARD_PARAM_NAME_STATUS(current) -> VCARD_PARAM_NAME_STATUS
458 * -> VCARD_PARAM_VALUE_STATUS -> VCARD_TYPE_VALUE_STATUS -> MOVE TO NEXT TYPE
460 else if(c == VTYPE_TOKEN_SEMICOLON) {
461 *pStatus = VCARD_PARAM_NAME_STATUS;
467 else if((c == '\r') || (c == '\n') || (_VIsSpace(c)));
476 __VCardFreeVTreeMemory(VTree * pTree)
479 VObject* pCurObj = NULL;
480 VObject* pNextObj = NULL;
482 VTree* pCurTree = NULL;
483 VTree* pNextTree = NULL;
485 VParam* pCurParam = NULL;
486 VParam* pNextParam = NULL;
491 SysRequireEx( pTree->treeType == VCARD, false );
492 SysRequireEx( pTree != NULL, false );
493 VDATA_TRACE("vcard_free_vtree_memory() entered.");
495 if (pTree->treeType != VCARD)
505 pNextTree = pCurTree->pNext;
506 pCurObj = pCurTree->pTop;
511 pNextObj = pCurObj->pSibling;
512 count = pCurObj->valueCount;
514 for ( i = 0; i < count; i++ ) {
515 VFREE( pCurObj->pszValue[i]);
518 #ifdef VDATA_GROUPNAME_SUPPORTED
519 if ( pCurObj->pszGroupName )
520 VFREE( pCurObj->pszGroupName );
523 if ( pCurObj->pParam )
526 pCurParam = pCurObj->pParam;
528 while(pCurParam != NULL)
530 pNextParam = pCurParam->pNext;
531 VDATA_TRACE("pNEXT ==> %p", pCurParam->pNext);
532 VDATA_TRACE("pPARAM ==> %p", pCurParam->parameter);
533 VDATA_TRACE("pVALUE ==> %p", pCurParam->paramValue);
534 VDATA_TRACE("pCurParam : %p", pCurParam);
535 VDATA_TRACE("pCurParam->parameter : %d", pCurParam->parameter);
536 VDATA_TRACE("pCurParam->paramValue : %d", pCurParam->paramValue);
537 if(pNextParam != NULL) {
538 VDATA_TRACE("pNextParam : %p", pNextParam);
539 VDATA_TRACE("pNextParam->parameter : %d", pNextParam->parameter);
540 VDATA_TRACE("pNextParam->paramValue : %d", pNextParam->paramValue);
543 pCurParam = pNextParam;
552 pCurTree = pNextTree;
555 VDATA_TRACE("exit vcard_free_vtree_memory");
561 * __VCardGetParamVal() fine the param value and returns value.
563 * @param pVCardRaw The raw data
564 * @param pStatus Decoder status
565 * @param pDLen retrived length
567 * @return buffer The result value
570 __VCardGetParamVal( char* pVCardRaw, int* pStatus, int* pDLen )
576 char* pTemp = pVCardRaw;
578 SysRequireEx( pVCardRaw, NULL );
581 GO_NEXT_CHAR(c, pVCardRaw, pDLen);
584 case VTYPE_TOKEN_SEMICOLON :
585 *pStatus = VCARD_PARAM_NAME_STATUS;
587 case VTYPE_TOKEN_COLON :
588 *pStatus = VCARD_TYPE_VALUE_STATUS;
590 case VTYPE_TOKEN_COMMA :
591 *pStatus = VCARD_PARAM_VALUE_STATUS;
594 if( c == VTYPE_TOKEN_SEMICOLON
595 || c == VTYPE_TOKEN_COLON
596 || c == VTYPE_TOKEN_COMMA
604 pBuf = (char *)malloc(len);
608 memset(pBuf, 0x00, len);
609 memcpy(pBuf, pTemp, len-1);
617 * __VCardGetTypeVal() fine the type value and returns value.
619 * @param pVCardRaw The raw data
620 * @param status Decoder status
621 * @return buffer The result value
624 __VCardGetTypeVal( char* pVCardRaw, int* pStatus, int* pDLen, int enc, VObject* pType)
631 bool bEscape = false;
635 char* pTemp = pVCardRaw;
636 char* pTmpBuf = NULL;
640 SysRequireEx( pVCardRaw, NULL );
644 GO_NEXT_CHAR(c, pVCardRaw, pDLen);
646 if( c == 0x00) break;
650 /** This case means that there are more type's value. */
651 if ( c == VTYPE_TOKEN_SEMICOLON && bEscape == false ) {
653 if((pBuf = (char *)malloc(len)) == NULL) return NULL;
655 memset(pBuf, 0x00, len);
656 memcpy(pBuf,pTemp,len-1);
661 *pStatus = VCARD_TYPE_VALUE_STATUS;
663 /** Base 64 Decoding */
664 if((enc & pEncList[1].flag) || (enc & pEncList[0].flag)) {
666 bufferCount = (len * 6 / 8) + 2;
668 if((pTmpBuf = (char *)malloc(bufferCount)) == NULL) {
673 memset(pTmpBuf, 0x00, bufferCount);
674 num = _VB64Decode(pTmpBuf, pBuf);
676 if(pType != NULL) pType->numOfBiData = num;
684 /** Quoted Printable Decoding */
685 if(enc & pEncList[2].flag) {
690 if(pBuf[i] == '\n' || pBuf[i] == '\r'){
692 if(pBuf[i] == '\n'|| pBuf[i] == '\r')
695 if(pBuf[j-1] == '=') j--;
698 pBuf[j++] = pBuf[i++];
711 else if(bEscape == true && c != VTYPE_TOKEN_SEMICOLON )
713 else if((c == '\r') || (c == '\n'))
717 if(c2 == '=' && (enc & pEncList[2].flag))
720 if((c1 == '\r') || (c1 == '\n'))
727 else if(__VCardGetTypeName(pVCardRaw, &Status, &Len) != UNKNOWN_NAME)
730 if((pBuf = (char *)malloc(len)) == NULL) return NULL;
732 memset(pBuf, 0x00, len);
733 memcpy(pBuf,pTemp,len-1);
738 *pStatus = VCARD_TYPE_NAME_STATUS;
742 if((c1 == '\r') || (c1 == '\n')) {
747 if((enc & pEncList[1].flag) || (enc & pEncList[0].flag)) {
749 bufferCount = (len * 6 / 8) + 5;
751 if((pTmpBuf = (char *)malloc(bufferCount)) == NULL) {
756 memset(pTmpBuf, 0x00, bufferCount);
757 num = _VB64Decode(pTmpBuf, pBuf);
760 pType->numOfBiData = num;
768 if(enc & pEncList[2].flag) {
774 if(pBuf[i] == '\n' || pBuf[i] == '\r')
777 if(pBuf[i] == '\n' || pBuf[i] == '\r')
780 if(pBuf[j-1] == '=') j--;
783 pBuf[j++] = pBuf[i++];
801 VCardGetTypeValue( int index )
804 VDATA_TRACE("VCardGetTypeValue() enter..\n");
806 return pTypeList[index].flag;
810 VCardGetValValue( int index )
813 VDATA_TRACE("VCardGetValValue() enter..\n");
815 return pValueList[index].flag;
819 VCardGetEncValue( int index )
822 VDATA_TRACE("VCardGetEncValue() enter..\n");
824 return pEncList[index].flag;
828 VCardGetCharsetValue( int index )
831 VDATA_TRACE("VCardGetCharsetValue() enter..\n");
833 return pCharsetList[index].flag;
837 * vcard_decode() decode the vCard data and returns vObject struct
839 * @param pVCardRaw The raw data
840 * @return vObject The result value
843 vcard_decode( char *pCardRaw )
846 char* szValue = NULL;
847 char* szCardBegin = NULL;
848 char* pCardRawTmp = NULL;
849 VTree* pVCard = NULL;
850 VParam* pTmpParam = NULL;
851 VObject* pTemp = NULL;
856 int status = VCARD_TYPE_NAME_STATUS;
861 int param_status = false;
862 int numberedParam = 0;
864 //int start_status = 0;
867 bool vcard_ended = false;
869 SysRequireEx(pCardRaw != NULL, NULL);
870 len = strlen(pCardRaw);
871 VDATA_TRACE("length of pCardRaw = %d", len);
873 pCardRaw = _VUnfoldingNoSpecNew(pCardRaw);
874 pCardRawTmp = pCardRaw;
875 len = _VManySpace2Space( pCardRaw );
877 VDATA_TRACE("ret value of _VManySpace2Space = %d", len);
879 if(!__VIsVcardFile(pCardRaw, CHECK_START)) {
890 if((c == '\0') || done)
894 case VCARD_TYPE_NAME_STATUS:
896 type = __VCardGetTypeName(pCardRaw, &status, &dLen);
904 case VCARD_TYPE_BEGIN:
910 if ( ( pVCard = ( VTree* )malloc( sizeof( VTree ) ) ) == NULL ) {
915 memset(pVCard,0x00, sizeof(VTree));
918 szCardBegin = __VCardGetTypeVal(pCardRaw, &status, &dLen, enc, NULL);
922 pVCard->treeType = VCARD;
925 pVCard->pNext = NULL;
930 if(strstr(pCardRaw,"VCARD") != NULL) {
936 status = VCARD_TYPE_NAME_STATUS;
946 if(UNKNOWN_NAME == type || type < 0) {
947 status = VCARD_TYPE_NAME_STATUS;
951 if ( ( pTemp = ( VObject* )malloc( sizeof( VObject ) ) ) == NULL ) {
955 memset( pTemp, 0, sizeof( VObject ) );
956 pTemp->property = type;
958 if ( pVCard->pTop == NULL ) {
959 pVCard->pTop = pTemp;
960 pVCard->pCur = pTemp;
963 pVCard->pCur->pSibling = pTemp;
964 pVCard->pCur = pTemp;
971 param_status = false;
974 #ifdef VDATA_GROUPNAME_SUPPORTED
975 if ( gszGroupName != NULL )
976 pVCard->pCur->pszGroupName = gszGroupName;
980 case VCARD_PARAM_NAME_STATUS:
983 param = __VCardGetParamName( pCardRaw, &status, &dLen );
986 if ( param_status != true ) {
988 if ( ( pTmpParam = ( VParam* )malloc( sizeof( VParam ) ) ) == NULL )
992 pVCard->pCur->pParam = pTmpParam;
993 memset( pTmpParam, 0x00, sizeof( VParam ) );
994 VDATA_TRACE("pTmpParam : %p", pTmpParam);
998 if ( ( pTmpParam->pNext = ( VParam* )malloc( sizeof( VParam ) ) ) == NULL )
1001 pTmpParam = pTmpParam->pNext;
1002 memset( pTmpParam, 0x00, sizeof(VParam));
1003 VDATA_TRACE("pTmpParam : %p", pTmpParam);
1006 pTmpParam->parameter = param;
1009 case VCARD_PARAM_VALUE_STATUS:
1012 switch ( pTmpParam->parameter )
1014 case VCARD_PARAM_TYPE:
1015 szValue = __VCardGetParamVal( pCardRaw, &status, &dLen );
1016 numberedParam |= __VCardGetValue( szValue, pTypeList, VCARD_TYPE_PARAM_NUM );
1018 case VCARD_PARAM_VALUE:
1019 szValue = __VCardGetParamVal( pCardRaw, &status, &dLen );
1020 numberedParam |= __VCardGetValue( szValue, pValueList, VCARD_VALUE_PARAM_NUM );
1022 case VCARD_PARAM_ENCODING:
1023 szValue = __VCardGetParamVal( pCardRaw, &status, &dLen );
1024 numberedParam |= __VCardGetValue( szValue, pEncList, VCARD_ENCODE_PARAM_NUM );
1025 enc = numberedParam;
1027 case VCARD_PARAM_CHARSET:
1028 szValue = __VCardGetParamVal( pCardRaw, &status, &dLen );
1029 numberedParam |= __VCardGetValue( szValue, pCharsetList, VCARD_CHARSET_PARAM_NUM );
1031 case VCARD_PARAM_CONTEXT:
1032 case VCARD_PARAM_LANGUAGE:
1033 // prevent 7605 08.03.13
1034 szValue = __VCardGetParamVal( pCardRaw, &status, &dLen );
1038 szValue = __VCardGetParamVal( pCardRaw, &status, &dLen );
1040 SET_PARAM_VALUE(numberedParam, szValue, pTypeList, VCARD_TYPE_PARAM_NUM, pTmpParam, VCARD_PARAM_TYPE, enc);
1041 SET_PARAM_VALUE(numberedParam, szValue, pValueList, VCARD_VALUE_PARAM_NUM, pTmpParam, VCARD_PARAM_VALUE, enc);
1042 SET_PARAM_VALUE(numberedParam, szValue, pEncList, VCARD_ENCODE_PARAM_NUM, pTmpParam, VCARD_PARAM_ENCODING, enc);
1043 SET_PARAM_VALUE(numberedParam, szValue, pCharsetList, VCARD_CHARSET_PARAM_NUM, pTmpParam, VCARD_PARAM_CHARSET, enc);
1052 VDATA_TRACE("%d, %s, %p",numberedParam, szValue, pTmpParam);
1053 pTmpParam->paramValue = numberedParam;
1054 pTmpParam->pNext = NULL;
1058 case VCARD_TYPE_VALUE_STATUS:
1060 temp = __VCardGetTypeVal( pCardRaw, &status, &dLen, enc, pVCard->pCur);
1062 if(valueCount <= VDATA_VALUE_COUNT_MAX) {
1063 pVCard->pCur->pszValue[valueCount] = temp;
1065 pVCard->pCur->valueCount = valueCount;
1077 if(pVCard->pTop == NULL)
1090 __VCardFreeVTreeMemory(pVCard);
1096 * vcard_encode() compares the string and vCard type, parameter value.
1098 * @param pVCardRaw Data which will be encoded
1099 * @return char * Encoded result
1102 vcard_encode( VTree *pVCardRaw )
1105 char* pVCardRes = NULL;
1106 VObject * pTmpObj = NULL;
1111 int lenTypeList = 0;
1113 LENGTH_TYPE_LIST(pszCardTypeList, lenTypeList);
1115 SysRequireEx(pVCardRaw != NULL, NULL);
1116 SysRequireEx(pVCardRaw->pTop != NULL, NULL);
1117 SysRequireEx(pVCardRaw->pTop->property >= 0, NULL);
1118 SysRequireEx(pVCardRaw->pTop->property < lenTypeList, NULL);
1119 SysRequireEx(pVCardRaw->treeType == VCARD, NULL);
1120 SysRequireEx(pVCardRaw->pTop->valueCount > 0, NULL);
1122 //VDATA_TRACE("START %d %d", pVCardRaw->pTop->property, lenTypeList);
1124 for(;cnt < pVCardRaw->pTop->valueCount;cnt++) {
1126 if(pVCardRaw->pTop->pszValue[cnt] == NULL) {
1127 VDATA_TRACE("pVCardRaw->pTop->valueCount : %d",pVCardRaw->pTop->valueCount);
1128 VDATA_TRACE("pVCardRaw->pTop->pszValue[%d] : %s", cnt, pVCardRaw->pTop->pszValue[cnt]);
1134 if ( ( pVCardRes = ( char * )malloc( sizeof( char ) * ( total += 14 + 14 ) ) ) == NULL )
1136 VDATA_TRACE( "vcard_encode:malloc failed\n" );
1141 memcpy( pVCardRes, "BEGIN:VCARD\r\n", 14 );
1142 strcat( pVCardRes, "VERSION:2.1\r\n" );
1144 pTmpObj = pVCardRaw->pTop;
1151 if ( ( pTemp = __VCardTypeEncode( pTmpObj, pszCardTypeList[pTmpObj->property] ) ) != NULL )
1153 len = strlen( pTemp );
1155 if ( ( pVCardRes = ( char* )realloc( pVCardRes, ( total += len+10 ) ) ) == NULL )
1157 VDATA_TRACE( "vcard_encode():realloc failed\n");
1164 if( strncmp(pTemp,"VERSION", strlen("VERSION")) != 0)
1165 strncat(pVCardRes, pTemp, strlen(pTemp));
1167 VDATA_TRACE("pTemp : %s", pTemp);
1173 if ( pTmpObj->pSibling != NULL )
1174 pTmpObj = pTmpObj->pSibling;
1179 if ( ( pVCardRes = ( char * )realloc( pVCardRes, ( total += 12 ) ) ) == NULL )
1181 VDATA_TRACE( "vcard_encode:realloc failed\n");
1185 strcat( pVCardRes, "END:VCARD\r\n" );
1192 * VIsVcardFile() verify VCard file.
1194 * @param pVCardRaw Data which will be encoded
1195 * @return int result (true or false)
1198 __VIsVcardFile(char *pCardRaw, int mode)
1201 bool rtnValue = true;
1202 char *pszVcardBegin = "BEGIN:VCARD";
1207 for(i=0; i < 11; i++)
1208 if(*pszVcardBegin++ != *pCardRaw++)
1221 * vCardTypeEncoder() compares the string and vCard type, parameter value.
1223 * @param typeObj Data which will be encoded
1224 * @param type Name of the type
1225 * @return char * Encoded result
1228 __VCardTypeEncode( VObject *pTypeObj, char *pType )
1233 char* szTypeValue = NULL;
1236 char* pEncode = NULL;
1241 len = strlen( pType );
1242 biLen = pTypeObj->numOfBiData;
1244 #ifdef VDATA_GROUPNAME_SUPPORTED
1245 if ( pTypeObj->pszGroupName != NULL )
1247 len += strlen( pTypeObj->pszGroupName ) + 1;
1249 #endif // VDATA_GROUPNAME_SUPPORTED
1250 if ( ( szTypeValue = ( char * )malloc( total += ( len+1 ) ) ) == NULL )
1252 VDATA_TRACE( "__VCardTypeEncode():malloc failed\n");
1256 memset( szTypeValue, '\0', ( len+1 ) );
1257 #ifdef VDATA_GROUPNAME_SUPPORTED
1258 if ( pTypeObj->pszGroupName != NULL )
1260 g_strlcat( szTypeValue, pTypeObj->pszGroupName, total);
1261 g_strlcat( szTypeValue, ".", total);
1263 #endif // VDATA_GROUPNAME_SUPPORTED
1264 g_strlcat( szTypeValue, pType, total);
1266 pTemp = __VCardParamEncode( pTypeObj, &enc );
1267 if ( pTemp != NULL )
1269 len = strlen( pTemp );
1270 if ( ( szTypeValue = ( char * )realloc( szTypeValue, ( total += len ) ) ) == NULL )
1272 VDATA_TRACE( "__VCardTypeEncode():realloc failed\n");
1278 g_strlcat( szTypeValue, pTemp, total);
1283 if ( ( szTypeValue = ( char * )realloc( szTypeValue, ( total += 2 ) ) ) == NULL )
1289 strcat( szTypeValue, ":" );
1293 if(strcmp(pType, pszCardTypeList[19]) != 0) {
1294 for ( i = 0; i < pTypeObj->valueCount; i++ ) {
1296 if(pTypeObj->pszValue[i] != NULL)
1297 len += strlen( pTypeObj->pszValue[i] );
1304 for ( i = 0; i < pTypeObj->valueCount; i++ ) {
1307 if ( ( pEncode = ( char * )malloc( len+20 ) ) == NULL ) {
1313 memset( pEncode, '\0', len+20 );
1315 if(strcmp(pType, pszCardTypeList[19]) != 0) {
1316 g_strlcat( pEncode, pTypeObj->pszValue[i], len+20);
1320 memcpy(pEncode, pTypeObj->pszValue[i], biLen);
1324 strncpy( buf, pTypeObj->pszValue[i], 999 );
1326 g_strlcat( pEncode, ";", len+20);
1327 g_strlcat( pEncode, buf, len+20);
1331 if(strcmp(pType, pszCardTypeList[19]) != 0) {
1333 strcat( pEncode, "\0\0" );
1334 len = strlen( pEncode );
1341 if ( enc & pEncList[2].flag ) {
1342 if((pRes = (char *)malloc(len * 6 + 10)) == NULL) {
1349 _VQPEncode( pRes, pEncode );
1352 else if(enc & pEncList[1].flag ) {
1353 if((pRes = (char *)malloc((len * 8 / 6) + 4)) == NULL){
1360 memset( pRes, '\0', ( ( len * 8 / 6 ) + 4 ) );
1361 _VB64Encode( pRes, pEncode, biLen );
1365 if((pRes = (char *)malloc(len+30)) == NULL) {
1371 memset( pRes, '\0', ( len + 30 ) );
1374 memcpy( pRes, pEncode, len );
1379 if((pRes = (char *)realloc(pRes, strlen(pRes) + 3)) == NULL)
1386 strncat( pRes, "\r\n", strlen(pRes) + 2);
1388 len = strlen( pRes );
1390 if ((szTypeValue = (char *)realloc(szTypeValue, (total += (len+3)))) == NULL) {
1397 strncat(szTypeValue, pRes, total - 1);
1399 if(strcmp(pType, pszCardTypeList[19]) != 0) {
1400 _VRLSpace( szTypeValue );
1401 _VRTSpace( szTypeValue );
1410 * __VCardParamEncode() Parameter Encoding.
1412 * @param pTypeObj Data which will be encoded
1413 * @param pEnc Name of the type
1416 __VCardParamEncode(VObject* pTypeObj, int* pEnc)
1424 char* szParam = NULL;
1425 VParam* pTemp = NULL;
1426 ValueObj* pList = NULL;
1428 /** Paramter initialize. */
1429 pTemp = pTypeObj->pParam;
1431 /** Momory Allocation for parameter string. */
1433 if ((szParam = (char*)malloc(len+=2)) == NULL)
1438 memset(szParam, 0x00, 2);
1441 /** appending pamaters. */
1444 if(pTemp == NULL) break;
1448 /** Expand szParam string. For appending.*/
1449 if((szParam = (char *)realloc(szParam, len += 15)) == NULL)
1455 /** appending paramter name. */
1456 strcat( szParam, ";" );
1457 if(pTemp->parameter != VCARD_PARAM_TYPE) {
1458 g_strlcat( szParam, pszCardParamList[pTemp->parameter], len);
1459 g_strlcat( szParam, "=", len);
1462 /** Set Parameter Value name. */
1463 switch ( pTemp->parameter )
1465 case VCARD_PARAM_ENCODING:
1466 *pEnc = pTemp->paramValue;
1467 shift = VCARD_ENCODE_PARAM_NUM;
1468 pList = pEncList; bSupported = true;
1470 case VCARD_PARAM_TYPE:
1471 shift = VCARD_TYPE_PARAM_NUM;
1472 pList = pTypeList; bSupported = true;
1474 case VCARD_PARAM_VALUE:
1475 shift = VCARD_VALUE_PARAM_NUM;
1476 pList = pValueList; bSupported = true;
1478 case VCARD_PARAM_CHARSET:
1479 shift = VCARD_CHARSET_PARAM_NUM;
1480 pList = pCharsetList; bSupported = true;
1483 if ( ( szParam = ( char* )realloc( szParam, 5 ) ) == NULL )
1488 strcat( szParam, "NONE" );
1491 /** exchage parameter value's to string.*/
1492 if(bSupported == true) {
1494 for(i = 0, sNum = 0x00000001; i < shift; i++) {
1496 if(pTemp->paramValue & sNum) {
1497 if((szParam = (char *)realloc(szParam, ( len += (strlen(pList[i].szName) + 2)))) == NULL)
1503 g_strlcat( szParam, pList[i].szName, len);
1504 g_strlcat( szParam, "; ", len);
1511 /** remove semicolon from tail. */
1512 for(i = strlen( szParam ); i > 0 ; i--) {
1514 if ( szParam[i] == ' ' && szParam[i-1] == ';' ) {
1515 szParam[i-1] = '\0';
1520 if ( pTemp->pNext != NULL )
1521 pTemp = pTemp->pNext;
1530 vcard_free_vtree_memory(VTree * pTree)
1539 return __VCardFreeVTreeMemory(pTree);