-rw-r--r-- | libopie/pim/ocontact.cpp | 30 | ||||
-rw-r--r-- | libopie/pim/ocontact.h | 5 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.cpp | 30 | ||||
-rw-r--r-- | libopie2/opiepim/ocontact.h | 5 |
4 files changed, 62 insertions, 8 deletions
diff --git a/libopie/pim/ocontact.cpp b/libopie/pim/ocontact.cpp index 21fc088..734f5a2 100644 --- a/libopie/pim/ocontact.cpp +++ b/libopie/pim/ocontact.cpp | |||
@@ -1093,91 +1093,112 @@ static VObject *createVObject( const OContact &c ) | |||
1093 | safeAddPropValue( work_adr, VCRegionProp, c.businessState() ); | 1093 | safeAddPropValue( work_adr, VCRegionProp, c.businessState() ); |
1094 | safeAddPropValue( work_adr, VCPostalCodeProp, c.businessZip() ); | 1094 | safeAddPropValue( work_adr, VCPostalCodeProp, c.businessZip() ); |
1095 | safeAddPropValue( work_adr, VCCountryNameProp, c.businessCountry() ); | 1095 | safeAddPropValue( work_adr, VCCountryNameProp, c.businessCountry() ); |
1096 | 1096 | ||
1097 | VObject *work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPhone() ); | 1097 | VObject *work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPhone() ); |
1098 | safeAddProp( work_phone, VCWorkProp ); | 1098 | safeAddProp( work_phone, VCWorkProp ); |
1099 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessMobile() ); | 1099 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessMobile() ); |
1100 | safeAddProp( work_phone, VCWorkProp ); | 1100 | safeAddProp( work_phone, VCWorkProp ); |
1101 | safeAddProp( work_phone, VCCellularProp ); | 1101 | safeAddProp( work_phone, VCCellularProp ); |
1102 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessFax() ); | 1102 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessFax() ); |
1103 | safeAddProp( work_phone, VCWorkProp ); | 1103 | safeAddProp( work_phone, VCWorkProp ); |
1104 | safeAddProp( work_phone, VCFaxProp ); | 1104 | safeAddProp( work_phone, VCFaxProp ); |
1105 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPager() ); | 1105 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPager() ); |
1106 | safeAddProp( work_phone, VCWorkProp ); | 1106 | safeAddProp( work_phone, VCWorkProp ); |
1107 | safeAddProp( work_phone, VCPagerProp ); | 1107 | safeAddProp( work_phone, VCPagerProp ); |
1108 | 1108 | ||
1109 | url = safeAddPropValue( vcard, VCURLProp, c.businessWebpage() ); | 1109 | url = safeAddPropValue( vcard, VCURLProp, c.businessWebpage() ); |
1110 | safeAddProp( url, VCWorkProp ); | 1110 | safeAddProp( url, VCWorkProp ); |
1111 | 1111 | ||
1112 | VObject *title = safeAddPropValue( vcard, VCTitleProp, c.jobTitle() ); | 1112 | VObject *title = safeAddPropValue( vcard, VCTitleProp, c.jobTitle() ); |
1113 | safeAddProp( title, VCWorkProp ); | 1113 | safeAddProp( title, VCWorkProp ); |
1114 | 1114 | ||
1115 | 1115 | ||
1116 | QStringList emails = c.emailList(); | 1116 | QStringList emails = c.emailList(); |
1117 | emails.prepend( c.defaultEmail() ); | 1117 | emails.prepend( c.defaultEmail() ); |
1118 | for( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { | 1118 | for( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { |
1119 | VObject *email = safeAddPropValue( vcard, VCEmailAddressProp, *it ); | 1119 | VObject *email = safeAddPropValue( vcard, VCEmailAddressProp, *it ); |
1120 | safeAddProp( email, VCInternetProp ); | 1120 | safeAddProp( email, VCInternetProp ); |
1121 | } | 1121 | } |
1122 | 1122 | ||
1123 | safeAddPropValue( vcard, VCNoteProp, c.notes() ); | 1123 | safeAddPropValue( vcard, VCNoteProp, c.notes() ); |
1124 | 1124 | ||
1125 | safeAddPropValue( vcard, VCBirthDateProp, TimeConversion::toString( c.birthday() ) ); | 1125 | // Exporting Birthday regarding RFC 2425 (5.8.4) |
1126 | if ( !c.birthday().isNull() ){ | ||
1127 | QString birthd_rfc2425 = c.birthday().year() + QString( "-" ) + c.birthday().month() + QString( "-" ) + c.birthday().day(); | ||
1128 | qWarning("Exporting birthday as: %s", birthd_rfc2425.latin1()); | ||
1129 | safeAddPropValue( vcard, VCBirthDateProp, birthd_rfc2425.latin1() ); | ||
1130 | } | ||
1126 | 1131 | ||
1127 | if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { | 1132 | if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { |
1128 | VObject *org = safeAddProp( vcard, VCOrgProp ); | 1133 | VObject *org = safeAddProp( vcard, VCOrgProp ); |
1129 | safeAddPropValue( org, VCOrgNameProp, c.company() ); | 1134 | safeAddPropValue( org, VCOrgNameProp, c.company() ); |
1130 | safeAddPropValue( org, VCOrgUnitProp, c.department() ); | 1135 | safeAddPropValue( org, VCOrgUnitProp, c.department() ); |
1131 | safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); | 1136 | safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); |
1132 | } | 1137 | } |
1133 | 1138 | ||
1134 | // some values we have to export as custom fields | 1139 | // some values we have to export as custom fields |
1135 | safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); | 1140 | safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); |
1136 | safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); | 1141 | safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); |
1137 | safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); | 1142 | safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); |
1138 | 1143 | ||
1139 | safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); | 1144 | safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); |
1140 | safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); | 1145 | safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); |
1141 | safeAddPropValue( vcard, "X-Qtopia-Anniversary", TimeConversion::toString( c.anniversary() ) ); | 1146 | safeAddPropValue( vcard, "X-Qtopia-Anniversary", TimeConversion::toString( c.anniversary() ) ); |
1142 | safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); | 1147 | safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); |
1143 | safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); | 1148 | safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); |
1144 | 1149 | ||
1145 | return vcard; | 1150 | return vcard; |
1146 | } | 1151 | } |
1147 | 1152 | ||
1148 | 1153 | ||
1149 | /*! | 1154 | /*! |
1150 | \internal | 1155 | \internal |
1151 | */ | 1156 | */ |
1157 | static QDate convVCardDateToDate( const QString& datestr ) | ||
1158 | { | ||
1159 | int monthPos = datestr.find('-'); | ||
1160 | int dayPos = datestr.find('-', monthPos+1 ); | ||
1161 | if ( monthPos == -1 || dayPos == -1 ) { | ||
1162 | qDebug("fromString didn't find - in str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); | ||
1163 | return QDate(); | ||
1164 | } | ||
1165 | int y = datestr.left( monthPos ).toInt(); | ||
1166 | int m = datestr.mid( monthPos+1, dayPos - monthPos - 1 ).toInt(); | ||
1167 | int d = datestr.mid( dayPos+1 ).toInt(); | ||
1168 | QDate date ( y,m,d ); | ||
1169 | qDebug("TimeConversion::fromString ymd = %s => %d %d %d; mpos = %d ypos = %d", datestr.latin1(), y, m, d, monthPos, dayPos); | ||
1170 | return date; | ||
1171 | } | ||
1172 | |||
1152 | static OContact parseVObject( VObject *obj ) | 1173 | static OContact parseVObject( VObject *obj ) |
1153 | { | 1174 | { |
1154 | OContact c; | 1175 | OContact c; |
1155 | 1176 | ||
1156 | VObjectIterator it; | 1177 | VObjectIterator it; |
1157 | initPropIterator( &it, obj ); | 1178 | initPropIterator( &it, obj ); |
1158 | while( moreIteration( &it ) ) { | 1179 | while( moreIteration( &it ) ) { |
1159 | VObject *o = nextVObject( &it ); | 1180 | VObject *o = nextVObject( &it ); |
1160 | QCString name = vObjectName( o ); | 1181 | QCString name = vObjectName( o ); |
1161 | QCString value = vObjectStringZValue( o ); | 1182 | QCString value = vObjectStringZValue( o ); |
1162 | if ( name == VCNameProp ) { | 1183 | if ( name == VCNameProp ) { |
1163 | VObjectIterator nit; | 1184 | VObjectIterator nit; |
1164 | initPropIterator( &nit, o ); | 1185 | initPropIterator( &nit, o ); |
1165 | while( moreIteration( &nit ) ) { | 1186 | while( moreIteration( &nit ) ) { |
1166 | VObject *o = nextVObject( &nit ); | 1187 | VObject *o = nextVObject( &nit ); |
1167 | QCString name = vObjectTypeInfo( o ); | 1188 | QCString name = vObjectTypeInfo( o ); |
1168 | QString value = vObjectStringZValue( o ); | 1189 | QString value = vObjectStringZValue( o ); |
1169 | if ( name == VCNamePrefixesProp ) | 1190 | if ( name == VCNamePrefixesProp ) |
1170 | c.setTitle( value ); | 1191 | c.setTitle( value ); |
1171 | else if ( name == VCNameSuffixesProp ) | 1192 | else if ( name == VCNameSuffixesProp ) |
1172 | c.setSuffix( value ); | 1193 | c.setSuffix( value ); |
1173 | else if ( name == VCFamilyNameProp ) | 1194 | else if ( name == VCFamilyNameProp ) |
1174 | c.setLastName( value ); | 1195 | c.setLastName( value ); |
1175 | else if ( name == VCGivenNameProp ) | 1196 | else if ( name == VCGivenNameProp ) |
1176 | c.setFirstName( value ); | 1197 | c.setFirstName( value ); |
1177 | else if ( name == VCAdditionalNamesProp ) | 1198 | else if ( name == VCAdditionalNamesProp ) |
1178 | c.setMiddleName( value ); | 1199 | c.setMiddleName( value ); |
1179 | } | 1200 | } |
1180 | } | 1201 | } |
1181 | else if ( name == VCAdrProp ) { | 1202 | else if ( name == VCAdrProp ) { |
1182 | bool work = TRUE; // default address is work address | 1203 | bool work = TRUE; // default address is work address |
1183 | QString street; | 1204 | QString street; |
@@ -1319,67 +1340,71 @@ static OContact parseVObject( VObject *obj ) | |||
1319 | else if ( name == VCOrgUnitProp ) | 1340 | else if ( name == VCOrgUnitProp ) |
1320 | c.setDepartment( value ); | 1341 | c.setDepartment( value ); |
1321 | else if ( name == VCOrgUnit2Prop ) | 1342 | else if ( name == VCOrgUnit2Prop ) |
1322 | c.setOffice( value ); | 1343 | c.setOffice( value ); |
1323 | } | 1344 | } |
1324 | } | 1345 | } |
1325 | else if ( name == VCTitleProp ) { | 1346 | else if ( name == VCTitleProp ) { |
1326 | c.setJobTitle( value ); | 1347 | c.setJobTitle( value ); |
1327 | } | 1348 | } |
1328 | else if ( name == "X-Qtopia-Profession" ) { | 1349 | else if ( name == "X-Qtopia-Profession" ) { |
1329 | c.setProfession( value ); | 1350 | c.setProfession( value ); |
1330 | } | 1351 | } |
1331 | else if ( name == "X-Qtopia-Manager" ) { | 1352 | else if ( name == "X-Qtopia-Manager" ) { |
1332 | c.setManager( value ); | 1353 | c.setManager( value ); |
1333 | } | 1354 | } |
1334 | else if ( name == "X-Qtopia-Assistant" ) { | 1355 | else if ( name == "X-Qtopia-Assistant" ) { |
1335 | c.setAssistant( value ); | 1356 | c.setAssistant( value ); |
1336 | } | 1357 | } |
1337 | else if ( name == "X-Qtopia-Spouse" ) { | 1358 | else if ( name == "X-Qtopia-Spouse" ) { |
1338 | c.setSpouse( value ); | 1359 | c.setSpouse( value ); |
1339 | } | 1360 | } |
1340 | else if ( name == "X-Qtopia-Gender" ) { | 1361 | else if ( name == "X-Qtopia-Gender" ) { |
1341 | c.setGender( value ); | 1362 | c.setGender( value ); |
1342 | } | 1363 | } |
1343 | else if ( name == "X-Qtopia-Anniversary" ) { | 1364 | else if ( name == "X-Qtopia-Anniversary" ) { |
1344 | c.setAnniversary( TimeConversion::fromString( value ) ); | 1365 | c.setAnniversary( TimeConversion::fromString( value ) ); |
1345 | } | 1366 | } |
1346 | else if ( name == "X-Qtopia-Nickname" ) { | 1367 | else if ( name == "X-Qtopia-Nickname" ) { |
1347 | c.setNickname( value ); | 1368 | c.setNickname( value ); |
1348 | } | 1369 | } |
1349 | else if ( name == "X-Qtopia-Children" ) { | 1370 | else if ( name == "X-Qtopia-Children" ) { |
1350 | c.setChildren( value ); | 1371 | c.setChildren( value ); |
1372 | } | ||
1373 | else if ( name == VCBirthDateProp ) { | ||
1374 | // Reading Birthdate regarding RFC 2425 (5.8.4) | ||
1375 | c.setBirthday( convVCardDateToDate( value ) ); | ||
1376 | |||
1351 | } | 1377 | } |
1352 | 1378 | ||
1353 | |||
1354 | #if 0 | 1379 | #if 0 |
1355 | else { | 1380 | else { |
1356 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); | 1381 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); |
1357 | VObjectIterator nit; | 1382 | VObjectIterator nit; |
1358 | initPropIterator( &nit, o ); | 1383 | initPropIterator( &nit, o ); |
1359 | while( moreIteration( &nit ) ) { | 1384 | while( moreIteration( &nit ) ) { |
1360 | VObject *o = nextVObject( &nit ); | 1385 | VObject *o = nextVObject( &nit ); |
1361 | QCString name = vObjectName( o ); | 1386 | QCString name = vObjectName( o ); |
1362 | QString value = vObjectStringZValue( o ); | 1387 | QString value = vObjectStringZValue( o ); |
1363 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); | 1388 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); |
1364 | } | 1389 | } |
1365 | } | 1390 | } |
1366 | #endif | 1391 | #endif |
1367 | } | 1392 | } |
1368 | c.setFileAs(); | 1393 | c.setFileAs(); |
1369 | return c; | 1394 | return c; |
1370 | } | 1395 | } |
1371 | 1396 | ||
1372 | /*! | 1397 | /*! |
1373 | Writes the list of \a contacts as a set of VCards to the file \a filename. | 1398 | Writes the list of \a contacts as a set of VCards to the file \a filename. |
1374 | */ | 1399 | */ |
1375 | void OContact::writeVCard( const QString &filename, const QValueList<OContact> &contacts) | 1400 | void OContact::writeVCard( const QString &filename, const QValueList<OContact> &contacts) |
1376 | { | 1401 | { |
1377 | QFileDirect f( filename.utf8().data() ); | 1402 | QFileDirect f( filename.utf8().data() ); |
1378 | if ( !f.open( IO_WriteOnly ) ) { | 1403 | if ( !f.open( IO_WriteOnly ) ) { |
1379 | qWarning("Unable to open vcard write"); | 1404 | qWarning("Unable to open vcard write"); |
1380 | return; | 1405 | return; |
1381 | } | 1406 | } |
1382 | 1407 | ||
1383 | QValueList<OContact>::ConstIterator it; | 1408 | QValueList<OContact>::ConstIterator it; |
1384 | for( it = contacts.begin(); it != contacts.end(); ++it ) { | 1409 | for( it = contacts.begin(); it != contacts.end(); ++it ) { |
1385 | VObject *obj = createVObject( *it ); | 1410 | VObject *obj = createVObject( *it ); |
@@ -1578,32 +1603,33 @@ void OContact::removeEmail( const QString &v ) | |||
1578 | 1603 | ||
1579 | // if default, then replace the default email with the first one | 1604 | // if default, then replace the default email with the first one |
1580 | if ( def == e ) { | 1605 | if ( def == e ) { |
1581 | //qDebug("removeEmail is default; setting new default"); | 1606 | //qDebug("removeEmail is default; setting new default"); |
1582 | if ( !emails.count() ) | 1607 | if ( !emails.count() ) |
1583 | clearEmails(); | 1608 | clearEmails(); |
1584 | else // setDefaultEmail will remove e from the list | 1609 | else // setDefaultEmail will remove e from the list |
1585 | setDefaultEmail( emails.first() ); | 1610 | setDefaultEmail( emails.first() ); |
1586 | } | 1611 | } |
1587 | } | 1612 | } |
1588 | void OContact::clearEmails() | 1613 | void OContact::clearEmails() |
1589 | { | 1614 | { |
1590 | mMap.remove( Qtopia::DefaultEmail ); | 1615 | mMap.remove( Qtopia::DefaultEmail ); |
1591 | mMap.remove( Qtopia::Emails ); | 1616 | mMap.remove( Qtopia::Emails ); |
1592 | } | 1617 | } |
1593 | void OContact::setDefaultEmail( const QString &v ) | 1618 | void OContact::setDefaultEmail( const QString &v ) |
1594 | { | 1619 | { |
1595 | QString e = v.simplifyWhiteSpace(); | 1620 | QString e = v.simplifyWhiteSpace(); |
1596 | 1621 | ||
1597 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); | 1622 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); |
1598 | replace( Qtopia::DefaultEmail, e ); | 1623 | replace( Qtopia::DefaultEmail, e ); |
1599 | 1624 | ||
1600 | if ( !e.isEmpty() ) | 1625 | if ( !e.isEmpty() ) |
1601 | insertEmail( e ); | 1626 | insertEmail( e ); |
1602 | 1627 | ||
1603 | } | 1628 | } |
1604 | 1629 | ||
1605 | void OContact::insertEmails( const QStringList &v ) | 1630 | void OContact::insertEmails( const QStringList &v ) |
1606 | { | 1631 | { |
1607 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) | 1632 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) |
1608 | insertEmail( *it ); | 1633 | insertEmail( *it ); |
1609 | } | 1634 | } |
1635 | |||
diff --git a/libopie/pim/ocontact.h b/libopie/pim/ocontact.h index 9e83150..382ab94 100644 --- a/libopie/pim/ocontact.h +++ b/libopie/pim/ocontact.h | |||
@@ -184,62 +184,63 @@ public: | |||
184 | // other | 184 | // other |
185 | QString notes() const { return find( Qtopia::Notes ); } | 185 | QString notes() const { return find( Qtopia::Notes ); } |
186 | QString groups() const { return find( Qtopia::Groups ); } | 186 | QString groups() const { return find( Qtopia::Groups ); } |
187 | QStringList groupList() const; | 187 | QStringList groupList() const; |
188 | 188 | ||
189 | // // custom | 189 | // // custom |
190 | // const QString &customField( const QString &key ) | 190 | // const QString &customField( const QString &key ) |
191 | // { return find( Custom- + key ); } | 191 | // { return find( Custom- + key ); } |
192 | 192 | ||
193 | static QStringList fields(); | 193 | static QStringList fields(); |
194 | static QStringList trfields(); | 194 | static QStringList trfields(); |
195 | static QStringList untrfields(); | 195 | static QStringList untrfields(); |
196 | 196 | ||
197 | QString toRichText() const; | 197 | QString toRichText() const; |
198 | QMap<int, QString> toMap() const; | 198 | QMap<int, QString> toMap() const; |
199 | QString field( int key ) const { return find( key ); } | 199 | QString field( int key ) const { return find( key ); } |
200 | 200 | ||
201 | 201 | ||
202 | // journaling... | 202 | // journaling... |
203 | void saveJournal( journal_action action, const QString &key = QString::null ); | 203 | void saveJournal( journal_action action, const QString &key = QString::null ); |
204 | void save( QString &buf ) const; | 204 | void save( QString &buf ) const; |
205 | 205 | ||
206 | void setUid( int i ) | 206 | void setUid( int i ) |
207 | { Record::setUid(i); replace( Qtopia::AddressUid , QString::number(i)); } | 207 | { Record::setUid(i); replace( Qtopia::AddressUid , QString::number(i)); } |
208 | 208 | ||
209 | QString toShortText()const; | 209 | QString toShortText()const; |
210 | QString OContact::type()const; | 210 | QString OContact::type()const; |
211 | QMap<QString,QString> OContact::toExtraMap() const; | 211 | QMap<QString,QString> OContact::toExtraMap() const; |
212 | class QString OContact::recordField(int) const; | 212 | class QString OContact::recordField(int) const; |
213 | 213 | ||
214 | // Why private ? (eilers,se) | 214 | // Why private ? (eilers,se) |
215 | QString emailSeparator() const { return " "; } | 215 | QString emailSeparator() const { return " "; } |
216 | // the emails should be seperated by a comma | 216 | // the emails should be seperated by a comma |
217 | void setEmails( const QString &v ); | 217 | void setEmails( const QString &v ); |
218 | QString emails() const { return find( Qtopia::Emails ); } | 218 | QString emails() const { return find( Qtopia::Emails ); } |
219 | 219 | ||
220 | 220 | ||
221 | private: | 221 | private: |
222 | friend class AbEditor; | 222 | friend class AbEditor; |
223 | friend class AbTable; | 223 | friend class AbTable; |
224 | friend class AddressBookAccessPrivate; | 224 | friend class AddressBookAccessPrivate; |
225 | friend class XMLIO; | 225 | friend class XMLIO; |
226 | 226 | ||
227 | |||
228 | void insert( int key, const QString &value ); | 227 | void insert( int key, const QString &value ); |
229 | void replace( int key, const QString &value ); | 228 | void replace( int key, const QString &value ); |
230 | QString find( int key ) const; | 229 | QString find( int key ) const; |
231 | 230 | ||
232 | QString displayAddress( const QString &street, | 231 | QString displayAddress( const QString &street, |
233 | const QString &city, | 232 | const QString &city, |
234 | const QString &state, | 233 | const QString &state, |
235 | const QString &zip, | 234 | const QString &zip, |
236 | const QString &country ) const; | 235 | const QString &country ) const; |
237 | 236 | ||
238 | Qtopia::UidGen &uidGen() { return sUidGen; } | 237 | Qtopia::UidGen &uidGen() { return sUidGen; } |
238 | |||
239 | |||
239 | static Qtopia::UidGen sUidGen; | 240 | static Qtopia::UidGen sUidGen; |
240 | QMap<int, QString> mMap; | 241 | QMap<int, QString> mMap; |
241 | ContactPrivate *d; | 242 | ContactPrivate *d; |
242 | }; | 243 | }; |
243 | 244 | ||
244 | 245 | ||
245 | #endif | 246 | #endif |
diff --git a/libopie2/opiepim/ocontact.cpp b/libopie2/opiepim/ocontact.cpp index 21fc088..734f5a2 100644 --- a/libopie2/opiepim/ocontact.cpp +++ b/libopie2/opiepim/ocontact.cpp | |||
@@ -1093,91 +1093,112 @@ static VObject *createVObject( const OContact &c ) | |||
1093 | safeAddPropValue( work_adr, VCRegionProp, c.businessState() ); | 1093 | safeAddPropValue( work_adr, VCRegionProp, c.businessState() ); |
1094 | safeAddPropValue( work_adr, VCPostalCodeProp, c.businessZip() ); | 1094 | safeAddPropValue( work_adr, VCPostalCodeProp, c.businessZip() ); |
1095 | safeAddPropValue( work_adr, VCCountryNameProp, c.businessCountry() ); | 1095 | safeAddPropValue( work_adr, VCCountryNameProp, c.businessCountry() ); |
1096 | 1096 | ||
1097 | VObject *work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPhone() ); | 1097 | VObject *work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPhone() ); |
1098 | safeAddProp( work_phone, VCWorkProp ); | 1098 | safeAddProp( work_phone, VCWorkProp ); |
1099 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessMobile() ); | 1099 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessMobile() ); |
1100 | safeAddProp( work_phone, VCWorkProp ); | 1100 | safeAddProp( work_phone, VCWorkProp ); |
1101 | safeAddProp( work_phone, VCCellularProp ); | 1101 | safeAddProp( work_phone, VCCellularProp ); |
1102 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessFax() ); | 1102 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessFax() ); |
1103 | safeAddProp( work_phone, VCWorkProp ); | 1103 | safeAddProp( work_phone, VCWorkProp ); |
1104 | safeAddProp( work_phone, VCFaxProp ); | 1104 | safeAddProp( work_phone, VCFaxProp ); |
1105 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPager() ); | 1105 | work_phone = safeAddPropValue( vcard, VCTelephoneProp, c.businessPager() ); |
1106 | safeAddProp( work_phone, VCWorkProp ); | 1106 | safeAddProp( work_phone, VCWorkProp ); |
1107 | safeAddProp( work_phone, VCPagerProp ); | 1107 | safeAddProp( work_phone, VCPagerProp ); |
1108 | 1108 | ||
1109 | url = safeAddPropValue( vcard, VCURLProp, c.businessWebpage() ); | 1109 | url = safeAddPropValue( vcard, VCURLProp, c.businessWebpage() ); |
1110 | safeAddProp( url, VCWorkProp ); | 1110 | safeAddProp( url, VCWorkProp ); |
1111 | 1111 | ||
1112 | VObject *title = safeAddPropValue( vcard, VCTitleProp, c.jobTitle() ); | 1112 | VObject *title = safeAddPropValue( vcard, VCTitleProp, c.jobTitle() ); |
1113 | safeAddProp( title, VCWorkProp ); | 1113 | safeAddProp( title, VCWorkProp ); |
1114 | 1114 | ||
1115 | 1115 | ||
1116 | QStringList emails = c.emailList(); | 1116 | QStringList emails = c.emailList(); |
1117 | emails.prepend( c.defaultEmail() ); | 1117 | emails.prepend( c.defaultEmail() ); |
1118 | for( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { | 1118 | for( QStringList::Iterator it = emails.begin(); it != emails.end(); ++it ) { |
1119 | VObject *email = safeAddPropValue( vcard, VCEmailAddressProp, *it ); | 1119 | VObject *email = safeAddPropValue( vcard, VCEmailAddressProp, *it ); |
1120 | safeAddProp( email, VCInternetProp ); | 1120 | safeAddProp( email, VCInternetProp ); |
1121 | } | 1121 | } |
1122 | 1122 | ||
1123 | safeAddPropValue( vcard, VCNoteProp, c.notes() ); | 1123 | safeAddPropValue( vcard, VCNoteProp, c.notes() ); |
1124 | 1124 | ||
1125 | safeAddPropValue( vcard, VCBirthDateProp, TimeConversion::toString( c.birthday() ) ); | 1125 | // Exporting Birthday regarding RFC 2425 (5.8.4) |
1126 | if ( !c.birthday().isNull() ){ | ||
1127 | QString birthd_rfc2425 = c.birthday().year() + QString( "-" ) + c.birthday().month() + QString( "-" ) + c.birthday().day(); | ||
1128 | qWarning("Exporting birthday as: %s", birthd_rfc2425.latin1()); | ||
1129 | safeAddPropValue( vcard, VCBirthDateProp, birthd_rfc2425.latin1() ); | ||
1130 | } | ||
1126 | 1131 | ||
1127 | if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { | 1132 | if ( !c.company().isEmpty() || !c.department().isEmpty() || !c.office().isEmpty() ) { |
1128 | VObject *org = safeAddProp( vcard, VCOrgProp ); | 1133 | VObject *org = safeAddProp( vcard, VCOrgProp ); |
1129 | safeAddPropValue( org, VCOrgNameProp, c.company() ); | 1134 | safeAddPropValue( org, VCOrgNameProp, c.company() ); |
1130 | safeAddPropValue( org, VCOrgUnitProp, c.department() ); | 1135 | safeAddPropValue( org, VCOrgUnitProp, c.department() ); |
1131 | safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); | 1136 | safeAddPropValue( org, VCOrgUnit2Prop, c.office() ); |
1132 | } | 1137 | } |
1133 | 1138 | ||
1134 | // some values we have to export as custom fields | 1139 | // some values we have to export as custom fields |
1135 | safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); | 1140 | safeAddPropValue( vcard, "X-Qtopia-Profession", c.profession() ); |
1136 | safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); | 1141 | safeAddPropValue( vcard, "X-Qtopia-Manager", c.manager() ); |
1137 | safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); | 1142 | safeAddPropValue( vcard, "X-Qtopia-Assistant", c.assistant() ); |
1138 | 1143 | ||
1139 | safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); | 1144 | safeAddPropValue( vcard, "X-Qtopia-Spouse", c.spouse() ); |
1140 | safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); | 1145 | safeAddPropValue( vcard, "X-Qtopia-Gender", c.gender() ); |
1141 | safeAddPropValue( vcard, "X-Qtopia-Anniversary", TimeConversion::toString( c.anniversary() ) ); | 1146 | safeAddPropValue( vcard, "X-Qtopia-Anniversary", TimeConversion::toString( c.anniversary() ) ); |
1142 | safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); | 1147 | safeAddPropValue( vcard, "X-Qtopia-Nickname", c.nickname() ); |
1143 | safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); | 1148 | safeAddPropValue( vcard, "X-Qtopia-Children", c.children() ); |
1144 | 1149 | ||
1145 | return vcard; | 1150 | return vcard; |
1146 | } | 1151 | } |
1147 | 1152 | ||
1148 | 1153 | ||
1149 | /*! | 1154 | /*! |
1150 | \internal | 1155 | \internal |
1151 | */ | 1156 | */ |
1157 | static QDate convVCardDateToDate( const QString& datestr ) | ||
1158 | { | ||
1159 | int monthPos = datestr.find('-'); | ||
1160 | int dayPos = datestr.find('-', monthPos+1 ); | ||
1161 | if ( monthPos == -1 || dayPos == -1 ) { | ||
1162 | qDebug("fromString didn't find - in str = %s; mpos = %d ypos = %d", datestr.latin1(), monthPos, dayPos ); | ||
1163 | return QDate(); | ||
1164 | } | ||
1165 | int y = datestr.left( monthPos ).toInt(); | ||
1166 | int m = datestr.mid( monthPos+1, dayPos - monthPos - 1 ).toInt(); | ||
1167 | int d = datestr.mid( dayPos+1 ).toInt(); | ||
1168 | QDate date ( y,m,d ); | ||
1169 | qDebug("TimeConversion::fromString ymd = %s => %d %d %d; mpos = %d ypos = %d", datestr.latin1(), y, m, d, monthPos, dayPos); | ||
1170 | return date; | ||
1171 | } | ||
1172 | |||
1152 | static OContact parseVObject( VObject *obj ) | 1173 | static OContact parseVObject( VObject *obj ) |
1153 | { | 1174 | { |
1154 | OContact c; | 1175 | OContact c; |
1155 | 1176 | ||
1156 | VObjectIterator it; | 1177 | VObjectIterator it; |
1157 | initPropIterator( &it, obj ); | 1178 | initPropIterator( &it, obj ); |
1158 | while( moreIteration( &it ) ) { | 1179 | while( moreIteration( &it ) ) { |
1159 | VObject *o = nextVObject( &it ); | 1180 | VObject *o = nextVObject( &it ); |
1160 | QCString name = vObjectName( o ); | 1181 | QCString name = vObjectName( o ); |
1161 | QCString value = vObjectStringZValue( o ); | 1182 | QCString value = vObjectStringZValue( o ); |
1162 | if ( name == VCNameProp ) { | 1183 | if ( name == VCNameProp ) { |
1163 | VObjectIterator nit; | 1184 | VObjectIterator nit; |
1164 | initPropIterator( &nit, o ); | 1185 | initPropIterator( &nit, o ); |
1165 | while( moreIteration( &nit ) ) { | 1186 | while( moreIteration( &nit ) ) { |
1166 | VObject *o = nextVObject( &nit ); | 1187 | VObject *o = nextVObject( &nit ); |
1167 | QCString name = vObjectTypeInfo( o ); | 1188 | QCString name = vObjectTypeInfo( o ); |
1168 | QString value = vObjectStringZValue( o ); | 1189 | QString value = vObjectStringZValue( o ); |
1169 | if ( name == VCNamePrefixesProp ) | 1190 | if ( name == VCNamePrefixesProp ) |
1170 | c.setTitle( value ); | 1191 | c.setTitle( value ); |
1171 | else if ( name == VCNameSuffixesProp ) | 1192 | else if ( name == VCNameSuffixesProp ) |
1172 | c.setSuffix( value ); | 1193 | c.setSuffix( value ); |
1173 | else if ( name == VCFamilyNameProp ) | 1194 | else if ( name == VCFamilyNameProp ) |
1174 | c.setLastName( value ); | 1195 | c.setLastName( value ); |
1175 | else if ( name == VCGivenNameProp ) | 1196 | else if ( name == VCGivenNameProp ) |
1176 | c.setFirstName( value ); | 1197 | c.setFirstName( value ); |
1177 | else if ( name == VCAdditionalNamesProp ) | 1198 | else if ( name == VCAdditionalNamesProp ) |
1178 | c.setMiddleName( value ); | 1199 | c.setMiddleName( value ); |
1179 | } | 1200 | } |
1180 | } | 1201 | } |
1181 | else if ( name == VCAdrProp ) { | 1202 | else if ( name == VCAdrProp ) { |
1182 | bool work = TRUE; // default address is work address | 1203 | bool work = TRUE; // default address is work address |
1183 | QString street; | 1204 | QString street; |
@@ -1319,67 +1340,71 @@ static OContact parseVObject( VObject *obj ) | |||
1319 | else if ( name == VCOrgUnitProp ) | 1340 | else if ( name == VCOrgUnitProp ) |
1320 | c.setDepartment( value ); | 1341 | c.setDepartment( value ); |
1321 | else if ( name == VCOrgUnit2Prop ) | 1342 | else if ( name == VCOrgUnit2Prop ) |
1322 | c.setOffice( value ); | 1343 | c.setOffice( value ); |
1323 | } | 1344 | } |
1324 | } | 1345 | } |
1325 | else if ( name == VCTitleProp ) { | 1346 | else if ( name == VCTitleProp ) { |
1326 | c.setJobTitle( value ); | 1347 | c.setJobTitle( value ); |
1327 | } | 1348 | } |
1328 | else if ( name == "X-Qtopia-Profession" ) { | 1349 | else if ( name == "X-Qtopia-Profession" ) { |
1329 | c.setProfession( value ); | 1350 | c.setProfession( value ); |
1330 | } | 1351 | } |
1331 | else if ( name == "X-Qtopia-Manager" ) { | 1352 | else if ( name == "X-Qtopia-Manager" ) { |
1332 | c.setManager( value ); | 1353 | c.setManager( value ); |
1333 | } | 1354 | } |
1334 | else if ( name == "X-Qtopia-Assistant" ) { | 1355 | else if ( name == "X-Qtopia-Assistant" ) { |
1335 | c.setAssistant( value ); | 1356 | c.setAssistant( value ); |
1336 | } | 1357 | } |
1337 | else if ( name == "X-Qtopia-Spouse" ) { | 1358 | else if ( name == "X-Qtopia-Spouse" ) { |
1338 | c.setSpouse( value ); | 1359 | c.setSpouse( value ); |
1339 | } | 1360 | } |
1340 | else if ( name == "X-Qtopia-Gender" ) { | 1361 | else if ( name == "X-Qtopia-Gender" ) { |
1341 | c.setGender( value ); | 1362 | c.setGender( value ); |
1342 | } | 1363 | } |
1343 | else if ( name == "X-Qtopia-Anniversary" ) { | 1364 | else if ( name == "X-Qtopia-Anniversary" ) { |
1344 | c.setAnniversary( TimeConversion::fromString( value ) ); | 1365 | c.setAnniversary( TimeConversion::fromString( value ) ); |
1345 | } | 1366 | } |
1346 | else if ( name == "X-Qtopia-Nickname" ) { | 1367 | else if ( name == "X-Qtopia-Nickname" ) { |
1347 | c.setNickname( value ); | 1368 | c.setNickname( value ); |
1348 | } | 1369 | } |
1349 | else if ( name == "X-Qtopia-Children" ) { | 1370 | else if ( name == "X-Qtopia-Children" ) { |
1350 | c.setChildren( value ); | 1371 | c.setChildren( value ); |
1372 | } | ||
1373 | else if ( name == VCBirthDateProp ) { | ||
1374 | // Reading Birthdate regarding RFC 2425 (5.8.4) | ||
1375 | c.setBirthday( convVCardDateToDate( value ) ); | ||
1376 | |||
1351 | } | 1377 | } |
1352 | 1378 | ||
1353 | |||
1354 | #if 0 | 1379 | #if 0 |
1355 | else { | 1380 | else { |
1356 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); | 1381 | printf("Name: %s, value=%s\n", name.data(), vObjectStringZValue( o ) ); |
1357 | VObjectIterator nit; | 1382 | VObjectIterator nit; |
1358 | initPropIterator( &nit, o ); | 1383 | initPropIterator( &nit, o ); |
1359 | while( moreIteration( &nit ) ) { | 1384 | while( moreIteration( &nit ) ) { |
1360 | VObject *o = nextVObject( &nit ); | 1385 | VObject *o = nextVObject( &nit ); |
1361 | QCString name = vObjectName( o ); | 1386 | QCString name = vObjectName( o ); |
1362 | QString value = vObjectStringZValue( o ); | 1387 | QString value = vObjectStringZValue( o ); |
1363 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); | 1388 | printf(" subprop: %s = %s\n", name.data(), value.latin1() ); |
1364 | } | 1389 | } |
1365 | } | 1390 | } |
1366 | #endif | 1391 | #endif |
1367 | } | 1392 | } |
1368 | c.setFileAs(); | 1393 | c.setFileAs(); |
1369 | return c; | 1394 | return c; |
1370 | } | 1395 | } |
1371 | 1396 | ||
1372 | /*! | 1397 | /*! |
1373 | Writes the list of \a contacts as a set of VCards to the file \a filename. | 1398 | Writes the list of \a contacts as a set of VCards to the file \a filename. |
1374 | */ | 1399 | */ |
1375 | void OContact::writeVCard( const QString &filename, const QValueList<OContact> &contacts) | 1400 | void OContact::writeVCard( const QString &filename, const QValueList<OContact> &contacts) |
1376 | { | 1401 | { |
1377 | QFileDirect f( filename.utf8().data() ); | 1402 | QFileDirect f( filename.utf8().data() ); |
1378 | if ( !f.open( IO_WriteOnly ) ) { | 1403 | if ( !f.open( IO_WriteOnly ) ) { |
1379 | qWarning("Unable to open vcard write"); | 1404 | qWarning("Unable to open vcard write"); |
1380 | return; | 1405 | return; |
1381 | } | 1406 | } |
1382 | 1407 | ||
1383 | QValueList<OContact>::ConstIterator it; | 1408 | QValueList<OContact>::ConstIterator it; |
1384 | for( it = contacts.begin(); it != contacts.end(); ++it ) { | 1409 | for( it = contacts.begin(); it != contacts.end(); ++it ) { |
1385 | VObject *obj = createVObject( *it ); | 1410 | VObject *obj = createVObject( *it ); |
@@ -1578,32 +1603,33 @@ void OContact::removeEmail( const QString &v ) | |||
1578 | 1603 | ||
1579 | // if default, then replace the default email with the first one | 1604 | // if default, then replace the default email with the first one |
1580 | if ( def == e ) { | 1605 | if ( def == e ) { |
1581 | //qDebug("removeEmail is default; setting new default"); | 1606 | //qDebug("removeEmail is default; setting new default"); |
1582 | if ( !emails.count() ) | 1607 | if ( !emails.count() ) |
1583 | clearEmails(); | 1608 | clearEmails(); |
1584 | else // setDefaultEmail will remove e from the list | 1609 | else // setDefaultEmail will remove e from the list |
1585 | setDefaultEmail( emails.first() ); | 1610 | setDefaultEmail( emails.first() ); |
1586 | } | 1611 | } |
1587 | } | 1612 | } |
1588 | void OContact::clearEmails() | 1613 | void OContact::clearEmails() |
1589 | { | 1614 | { |
1590 | mMap.remove( Qtopia::DefaultEmail ); | 1615 | mMap.remove( Qtopia::DefaultEmail ); |
1591 | mMap.remove( Qtopia::Emails ); | 1616 | mMap.remove( Qtopia::Emails ); |
1592 | } | 1617 | } |
1593 | void OContact::setDefaultEmail( const QString &v ) | 1618 | void OContact::setDefaultEmail( const QString &v ) |
1594 | { | 1619 | { |
1595 | QString e = v.simplifyWhiteSpace(); | 1620 | QString e = v.simplifyWhiteSpace(); |
1596 | 1621 | ||
1597 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); | 1622 | //qDebug("OContact::setDefaultEmail %s", e.latin1()); |
1598 | replace( Qtopia::DefaultEmail, e ); | 1623 | replace( Qtopia::DefaultEmail, e ); |
1599 | 1624 | ||
1600 | if ( !e.isEmpty() ) | 1625 | if ( !e.isEmpty() ) |
1601 | insertEmail( e ); | 1626 | insertEmail( e ); |
1602 | 1627 | ||
1603 | } | 1628 | } |
1604 | 1629 | ||
1605 | void OContact::insertEmails( const QStringList &v ) | 1630 | void OContact::insertEmails( const QStringList &v ) |
1606 | { | 1631 | { |
1607 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) | 1632 | for ( QStringList::ConstIterator it = v.begin(); it != v.end(); ++it ) |
1608 | insertEmail( *it ); | 1633 | insertEmail( *it ); |
1609 | } | 1634 | } |
1635 | |||
diff --git a/libopie2/opiepim/ocontact.h b/libopie2/opiepim/ocontact.h index 9e83150..382ab94 100644 --- a/libopie2/opiepim/ocontact.h +++ b/libopie2/opiepim/ocontact.h | |||
@@ -184,62 +184,63 @@ public: | |||
184 | // other | 184 | // other |
185 | QString notes() const { return find( Qtopia::Notes ); } | 185 | QString notes() const { return find( Qtopia::Notes ); } |
186 | QString groups() const { return find( Qtopia::Groups ); } | 186 | QString groups() const { return find( Qtopia::Groups ); } |
187 | QStringList groupList() const; | 187 | QStringList groupList() const; |
188 | 188 | ||
189 | // // custom | 189 | // // custom |
190 | // const QString &customField( const QString &key ) | 190 | // const QString &customField( const QString &key ) |
191 | // { return find( Custom- + key ); } | 191 | // { return find( Custom- + key ); } |
192 | 192 | ||
193 | static QStringList fields(); | 193 | static QStringList fields(); |
194 | static QStringList trfields(); | 194 | static QStringList trfields(); |
195 | static QStringList untrfields(); | 195 | static QStringList untrfields(); |
196 | 196 | ||
197 | QString toRichText() const; | 197 | QString toRichText() const; |
198 | QMap<int, QString> toMap() const; | 198 | QMap<int, QString> toMap() const; |
199 | QString field( int key ) const { return find( key ); } | 199 | QString field( int key ) const { return find( key ); } |
200 | 200 | ||
201 | 201 | ||
202 | // journaling... | 202 | // journaling... |
203 | void saveJournal( journal_action action, const QString &key = QString::null ); | 203 | void saveJournal( journal_action action, const QString &key = QString::null ); |
204 | void save( QString &buf ) const; | 204 | void save( QString &buf ) const; |
205 | 205 | ||
206 | void setUid( int i ) | 206 | void setUid( int i ) |
207 | { Record::setUid(i); replace( Qtopia::AddressUid , QString::number(i)); } | 207 | { Record::setUid(i); replace( Qtopia::AddressUid , QString::number(i)); } |
208 | 208 | ||
209 | QString toShortText()const; | 209 | QString toShortText()const; |
210 | QString OContact::type()const; | 210 | QString OContact::type()const; |
211 | QMap<QString,QString> OContact::toExtraMap() const; | 211 | QMap<QString,QString> OContact::toExtraMap() const; |
212 | class QString OContact::recordField(int) const; | 212 | class QString OContact::recordField(int) const; |
213 | 213 | ||
214 | // Why private ? (eilers,se) | 214 | // Why private ? (eilers,se) |
215 | QString emailSeparator() const { return " "; } | 215 | QString emailSeparator() const { return " "; } |
216 | // the emails should be seperated by a comma | 216 | // the emails should be seperated by a comma |
217 | void setEmails( const QString &v ); | 217 | void setEmails( const QString &v ); |
218 | QString emails() const { return find( Qtopia::Emails ); } | 218 | QString emails() const { return find( Qtopia::Emails ); } |
219 | 219 | ||
220 | 220 | ||
221 | private: | 221 | private: |
222 | friend class AbEditor; | 222 | friend class AbEditor; |
223 | friend class AbTable; | 223 | friend class AbTable; |
224 | friend class AddressBookAccessPrivate; | 224 | friend class AddressBookAccessPrivate; |
225 | friend class XMLIO; | 225 | friend class XMLIO; |
226 | 226 | ||
227 | |||
228 | void insert( int key, const QString &value ); | 227 | void insert( int key, const QString &value ); |
229 | void replace( int key, const QString &value ); | 228 | void replace( int key, const QString &value ); |
230 | QString find( int key ) const; | 229 | QString find( int key ) const; |
231 | 230 | ||
232 | QString displayAddress( const QString &street, | 231 | QString displayAddress( const QString &street, |
233 | const QString &city, | 232 | const QString &city, |
234 | const QString &state, | 233 | const QString &state, |
235 | const QString &zip, | 234 | const QString &zip, |
236 | const QString &country ) const; | 235 | const QString &country ) const; |
237 | 236 | ||
238 | Qtopia::UidGen &uidGen() { return sUidGen; } | 237 | Qtopia::UidGen &uidGen() { return sUidGen; } |
238 | |||
239 | |||
239 | static Qtopia::UidGen sUidGen; | 240 | static Qtopia::UidGen sUidGen; |
240 | QMap<int, QString> mMap; | 241 | QMap<int, QString> mMap; |
241 | ContactPrivate *d; | 242 | ContactPrivate *d; |
242 | }; | 243 | }; |
243 | 244 | ||
244 | 245 | ||
245 | #endif | 246 | #endif |