-rw-r--r-- | libopie/pim/ocontact.cpp | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index 8a0930b..b0f0d7f 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -1123,65 +1123,65 @@ static VObject *createVObject( const OContact &c ) | |||
1123 | 1123 | ||
1124 | safeAddPropValue( vcard, VCNoteProp, c.notes() ); | 1124 | safeAddPropValue( vcard, VCNoteProp, c.notes() ); |
1125 | 1125 | ||
1126 | // Exporting Birthday regarding RFC 2425 (5.8.4) | 1126 | // Exporting Birthday regarding RFC 2425 (5.8.4) |
1127 | if ( c.birthday().isValid() ){ | 1127 | if ( c.birthday().isValid() ){ |
1128 | QString birthd_rfc2425 = QString("%1-%2-%3") | 1128 | QString birthd_rfc2425 = QString("%1-%2-%3") |
1129 | .arg( c.birthday().year() ) | 1129 | .arg( c.birthday().year() ) |
1130 | .arg( c.birthday().month(), 2 ) | 1130 | .arg( c.birthday().month(), 2 ) |
1131 | .arg( c.birthday().day(), 2 ); | 1131 | .arg( c.birthday().day(), 2 ); |
1132 | // Now replace spaces with "0"... | 1132 | // Now replace spaces with "0"... |
1133 | int pos = 0; | 1133 | int pos = 0; |
1134 | while ( ( pos = birthd_rfc2425.find (' ') ) > 0 ) | 1134 | while ( ( pos = birthd_rfc2425.find (' ') ) > 0 ) |
1135 | birthd_rfc2425.replace( pos, 1, "0" ); | 1135 | birthd_rfc2425.replace( pos, 1, "0" ); |
1136 | 1136 | ||
1137 | qWarning("Exporting birthday as: %s", birthd_rfc2425.latin1()); | 1137 | qWarning("Exporting birthday as: %s", birthd_rfc2425.latin1()); |
1138 | safeAddPropValue( vcard, VCBirthDateProp, birthd_rfc2425.latin1() ); | 1138 | safeAddPropValue( vcard, VCBirthDateProp, birthd_rfc2425.latin1() ); |
1139 | } | 1139 | } |
1140 | 1140 | ||
1141 | if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { | 1141 | if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { |
1142 | VObject *org = safeAddProp( vcard, VCOrgProp ); | 1142 | VObject *org = safeAddProp( vcard, VCOrgProp ); |
1143 | safeAddPropValue( org, VCOrgNameProp, c.company() ); | 1143 | safeAddPropValue( org, VCOrgNameProp, c.company() ); |
1144 | safeAddPropValue( org, VCOrgUnitProp, c.department() ); | 1144 | safeAddPropValue( org, VCOrgUnitProp, c.department() ); |
1145 | safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); | 1145 | safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); |
1146 | } | 1146 | } |
1147 | 1147 | ||
1148 | // some values we have to export as custom fields | 1148 | // some values we have to export as custom fields |
1149 | safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); | 1149 | safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); |
1150 | safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); | 1150 | safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); |
1151 | safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); | 1151 | safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); |
1152 | 1152 | ||
1153 | safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); | 1153 | safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); |
1154 | safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); | 1154 | safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); |
1155 | safeAddPropValue( vcard, "X-Qtopia-Anniversary", TimeConversion::toString( c.anniversary() ) ); | 1155 | // safeAddPropValue( vcard, "X-Qtopia-Anniversary", TimeConversion::toString( c.anniversary() ) ); :SX |
1156 | safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); | 1156 | safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); |
1157 | safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); | 1157 | safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); |
1158 | 1158 | ||
1159 | return vcard; | 1159 | return vcard; |
1160 | } | 1160 | } |
1161 | 1161 | ||
1162 | 1162 | ||
1163 | /*! | 1163 | /*! |
1164 | \internal | 1164 | \internal |
1165 | */ | 1165 | */ |
1166 | static QDate convVCardDateToDate( const QString& datestr ) | 1166 | static QDate convVCardDateToDate( const QString& datestr ) |
1167 | { | 1167 | { |
1168 | int monthPos = datestr.find('-'); | 1168 | int monthPos = datestr.find('-'); |
1169 | int dayPos = datestr.find('-', monthPos+1 ); | 1169 | int dayPos = datestr.find('-', monthPos+1 ); |
1170 | int sep_ignore = 1; | 1170 | int sep_ignore = 1; |
1171 | if ( monthPos == -1 || dayPos == -1 ) { | 1171 | if ( monthPos == -1 || dayPos == -1 ) { |
1172 | qDebug("fromString didn't find - in str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); | 1172 | qDebug("fromString didn't find - in str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); |
1173 | // Ok.. No "-" found, therefore we will try to read other format ( YYYYMMDD ) | 1173 | // Ok.. No "-" found, therefore we will try to read other format ( YYYYMMDD ) |
1174 | if ( datestr.length() == 8 ){ | 1174 | if ( datestr.length() == 8 ){ |
1175 | monthPos = 4; | 1175 | monthPos = 4; |
1176 | dayPos = 6; | 1176 | dayPos = 6; |
1177 | sep_ignore = 0; | 1177 | sep_ignore = 0; |
1178 | qDebug("Try with follwing positions str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); | 1178 | qDebug("Try with follwing positions str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); |
1179 | } else { | 1179 | } else { |
1180 | return QDate(); | 1180 | return QDate(); |
1181 | } | 1181 | } |
1182 | } | 1182 | } |
1183 | int y = datestr.left( monthPos ).toInt(); | 1183 | int y = datestr.left( monthPos ).toInt(); |
1184 | int m = datestr.mid( monthPos + sep_ignore, dayPos - monthPos - sep_ignore ).toInt(); | 1184 | int m = datestr.mid( monthPos + sep_ignore, dayPos - monthPos - sep_ignore ).toInt(); |
1185 | int d = datestr.mid( dayPos + sep_ignore ).toInt(); | 1185 | int d = datestr.mid( dayPos + sep_ignore ).toInt(); |
1186 | qDebug("TimeConversion::fromString ymd = %s => %d %d %d; mpos = %d ypos = %d", datestr.latin1(), y, m, d, monthPos, dayPos); | 1186 | qDebug("TimeConversion::fromString ymd = %s => %d %d %d; mpos = %d ypos = %d", datestr.latin1(), y, m, d, monthPos, dayPos); |
1187 | QDate date ( y,m,d ); | 1187 | QDate date ( y,m,d ); |
@@ -1202,64 +1202,65 @@ static OContact parseVObject( VObject *obj ) | |||
1202 | VObjectIterator nit; | 1202 | VObjectIterator nit; |
1203 | initPropIterator( &nit, o ); | 1203 | initPropIterator( &nit, o ); |
1204 | while( moreIteration( &nit ) ) { | 1204 | while( moreIteration( &nit ) ) { |
1205 | VObject *o = nextVObject( &nit ); | 1205 | VObject *o = nextVObject( &nit ); |
1206 | QCString name = vObjectTypeInfo( o ); | 1206 | QCString name = vObjectTypeInfo( o ); |
1207 | QString value = vObjectStringZValue( o ); | 1207 | QString value = vObjectStringZValue( o ); |
1208 | if ( name == VCNamePrefixesProp ) | 1208 | if ( name == VCNamePrefixesProp ) |
1209 | c.setTitle( value ); | 1209 | c.setTitle( value ); |
1210 | else if ( name == VCNameSuffixesProp ) | 1210 | else if ( name == VCNameSuffixesProp ) |
1211 | c.setSuffix( value ); | 1211 | c.setSuffix( value ); |
1212 | else if ( name == VCFamilyNameProp ) | 1212 | else if ( name == VCFamilyNameProp ) |
1213 | c.setLastName( value ); | 1213 | c.setLastName( value ); |
1214 | else if ( name == VCGivenNameProp ) | 1214 | else if ( name == VCGivenNameProp ) |
1215 | c.setFirstName( value ); | 1215 | c.setFirstName( value ); |
1216 | else if ( name == VCAdditionalNamesProp ) | 1216 | else if ( name == VCAdditionalNamesProp ) |
1217 | c.setMiddleName( value ); | 1217 | c.setMiddleName( value ); |
1218 | } | 1218 | } |
1219 | } | 1219 | } |
1220 | else if ( name == VCAdrProp ) { | 1220 | else if ( name == VCAdrProp ) { |
1221 | bool work = TRUE; // default address is work address | 1221 | bool work = TRUE; // default address is work address |
1222 | QString street; | 1222 | QString street; |
1223 | QString city; | 1223 | QString city; |
1224 | QString region; | 1224 | QString region; |
1225 | QString postal; | 1225 | QString postal; |
1226 | QString country; | 1226 | QString country; |
1227 | 1227 | ||
1228 | VObjectIterator nit; | 1228 | VObjectIterator nit; |
1229 | initPropIterator( &nit, o ); | 1229 | initPropIterator( &nit, o ); |
1230 | while( moreIteration( &nit ) ) { | 1230 | while( moreIteration( &nit ) ) { |
1231 | VObject *o = nextVObject( &nit ); | 1231 | VObject *o = nextVObject( &nit ); |
1232 | QCString name = vObjectName( o ); | 1232 | QCString name = vObjectName( o ); |
1233 | QString value = vObjectStringZValue( o ); | 1233 | QString value = vObjectStringZValue( o ); |
1234 | |||
1234 | if ( name == VCHomeProp ) | 1235 | if ( name == VCHomeProp ) |
1235 | work = FALSE; | 1236 | work = FALSE; |
1236 | else if ( name == VCWorkProp ) | 1237 | else if ( name == VCWorkProp ) |
1237 | work = TRUE; | 1238 | work = TRUE; |
1238 | else if ( name == VCStreetAddressProp ) | 1239 | else if ( name == VCStreetAddressProp ) |
1239 | street = value; | 1240 | street = value; |
1240 | else if ( name == VCCityProp ) | 1241 | else if ( name == VCCityProp ) |
1241 | city = value; | 1242 | city = value; |
1242 | else if ( name == VCRegionProp ) | 1243 | else if ( name == VCRegionProp ) |
1243 | region = value; | 1244 | region = value; |
1244 | else if ( name == VCPostalCodeProp ) | 1245 | else if ( name == VCPostalCodeProp ) |
1245 | postal = value; | 1246 | postal = value; |
1246 | else if ( name == VCCountryNameProp ) | 1247 | else if ( name == VCCountryNameProp ) |
1247 | country = value; | 1248 | country = value; |
1248 | } | 1249 | } |
1249 | if ( work ) { | 1250 | if ( work ) { |
1250 | c.setBusinessStreet( street ); | 1251 | c.setBusinessStreet( street ); |
1251 | c.setBusinessCity( city ); | 1252 | c.setBusinessCity( city ); |
1252 | c.setBusinessCountry( country ); | 1253 | c.setBusinessCountry( country ); |
1253 | c.setBusinessZip( postal ); | 1254 | c.setBusinessZip( postal ); |
1254 | c.setBusinessState( region ); | 1255 | c.setBusinessState( region ); |
1255 | } else { | 1256 | } else { |
1256 | c.setHomeStreet( street ); | 1257 | c.setHomeStreet( street ); |
1257 | c.setHomeCity( city ); | 1258 | c.setHomeCity( city ); |
1258 | c.setHomeCountry( country ); | 1259 | c.setHomeCountry( country ); |
1259 | c.setHomeZip( postal ); | 1260 | c.setHomeZip( postal ); |
1260 | c.setHomeState( region ); | 1261 | c.setHomeState( region ); |
1261 | } | 1262 | } |
1262 | } | 1263 | } |
1263 | else if ( name == VCTelephoneProp ) { | 1264 | else if ( name == VCTelephoneProp ) { |
1264 | enum { | 1265 | enum { |
1265 | HOME = 0x01, | 1266 | HOME = 0x01, |
@@ -1351,65 +1352,65 @@ static OContact parseVObject( VObject *obj ) | |||
1351 | initPropIterator( &nit, o ); | 1352 | initPropIterator( &nit, o ); |
1352 | while( moreIteration( &nit ) ) { | 1353 | while( moreIteration( &nit ) ) { |
1353 | VObject *o = nextVObject( &nit ); | 1354 | VObject *o = nextVObject( &nit ); |
1354 | QCString name = vObjectName( o ); | 1355 | QCString name = vObjectName( o ); |
1355 | QString value = vObjectStringZValue( o ); | 1356 | QString value = vObjectStringZValue( o ); |
1356 | if ( name == VCOrgNameProp ) | 1357 | if ( name == VCOrgNameProp ) |
1357 | c.setCompany( value ); | 1358 | c.setCompany( value ); |
1358 | else if ( name == VCOrgUnitProp ) | 1359 | else if ( name == VCOrgUnitProp ) |
1359 | c.setDepartment( value ); | 1360 | c.setDepartment( value ); |
1360 | else if ( name == VCOrgUnit2Prop ) | 1361 | else if ( name == VCOrgUnit2Prop ) |
1361 | c.setOffice( value ); | 1362 | c.setOffice( value ); |
1362 | } | 1363 | } |
1363 | } | 1364 | } |
1364 | else if ( name == VCTitleProp ) { | 1365 | else if ( name == VCTitleProp ) { |
1365 | c.setJobTitle( value ); | 1366 | c.setJobTitle( value ); |
1366 | } | 1367 | } |
1367 | else if ( name == "X-Qtopia-Profession" ) { | 1368 | else if ( name == "X-Qtopia-Profession" ) { |
1368 | c.setProfession( value ); | 1369 | c.setProfession( value ); |
1369 | } | 1370 | } |
1370 | else if ( name == "X-Qtopia-Manager" ) { | 1371 | else if ( name == "X-Qtopia-Manager" ) { |
1371 | c.setManager( value ); | 1372 | c.setManager( value ); |
1372 | } | 1373 | } |
1373 | else if ( name == "X-Qtopia-Assistant" ) { | 1374 | else if ( name == "X-Qtopia-Assistant" ) { |
1374 | c.setAssistant( value ); | 1375 | c.setAssistant( value ); |
1375 | } | 1376 | } |
1376 | else if ( name == "X-Qtopia-Spouse" ) { | 1377 | else if ( name == "X-Qtopia-Spouse" ) { |
1377 | c.setSpouse( value ); | 1378 | c.setSpouse( value ); |
1378 | } | 1379 | } |
1379 | else if ( name == "X-Qtopia-Gender" ) { | 1380 | else if ( name == "X-Qtopia-Gender" ) { |
1380 | c.setGender( value ); | 1381 | c.setGender( value ); |
1381 | } | 1382 | } |
1382 | else if ( name == "X-Qtopia-Anniversary" ) { | 1383 | else if ( name == "X-Qtopia-Anniversary" ) { |
1383 | c.setAnniversary( TimeConversion::fromString( value ) ); | 1384 | // c.setAnniversary( TimeConversion::fromString( value ) ); :SX |
1384 | } | 1385 | } |
1385 | else if ( name == "X-Qtopia-Nickname" ) { | 1386 | else if ( name == "X-Qtopia-Nickname" ) { |
1386 | c.setNickname( value ); | 1387 | c.setNickname( value ); |
1387 | } | 1388 | } |
1388 | else if ( name == "X-Qtopia-Children" ) { | 1389 | else if ( name == "X-Qtopia-Children" ) { |
1389 | c.setChildren( value ); | 1390 | c.setChildren( value ); |
1390 | } | 1391 | } |
1391 | else if ( name == VCBirthDateProp ) { | 1392 | else if ( name == VCBirthDateProp ) { |
1392 | // Reading Birthdate regarding RFC 2425 (5.8.4) | 1393 | // Reading Birthdate regarding RFC 2425 (5.8.4) |
1393 | c.setBirthday( convVCardDateToDate( value ) ); | 1394 | c.setBirthday( convVCardDateToDate( value ) ); |
1394 | 1395 | ||
1395 | } | 1396 | } |
1396 | 1397 | ||
1397 | #if 0 | 1398 | #if 0 |
1398 | else { | 1399 | else { |
1399 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); | 1400 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); |
1400 | VObjectIterator nit; | 1401 | VObjectIterator nit; |
1401 | initPropIterator( &nit, o ); | 1402 | initPropIterator( &nit, o ); |
1402 | while( moreIteration( &nit ) ) { | 1403 | while( moreIteration( &nit ) ) { |
1403 | VObject *o = nextVObject( &nit ); | 1404 | VObject *o = nextVObject( &nit ); |
1404 | QCString name = vObjectName( o ); | 1405 | QCString name = vObjectName( o ); |
1405 | QString value = vObjectStringZValue( o ); | 1406 | QString value = vObjectStringZValue( o ); |
1406 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); | 1407 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); |
1407 | } | 1408 | } |
1408 | } | 1409 | } |
1409 | #endif | 1410 | #endif |
1410 | } | 1411 | } |
1411 | c.setFileAs(); | 1412 | c.setFileAs(); |
1412 | return c; | 1413 | return c; |
1413 | } | 1414 | } |
1414 | 1415 | ||
1415 | /*! | 1416 | /*! |