-rw-r--r-- | kabc/addressee.cpp | 31 |
1 files changed, 19 insertions, 12 deletions
diff --git a/kabc/addressee.cpp b/kabc/addressee.cpp index 0157721..3a2dc5f 100644 --- a/kabc/addressee.cpp +++ b/kabc/addressee.cpp | |||
@@ -101,97 +101,97 @@ Addressee::Addressee() | |||
101 | Addressee::~Addressee() | 101 | Addressee::~Addressee() |
102 | { | 102 | { |
103 | } | 103 | } |
104 | 104 | ||
105 | Addressee::Addressee( const Addressee &a ) | 105 | Addressee::Addressee( const Addressee &a ) |
106 | { | 106 | { |
107 | mData = a.mData; | 107 | mData = a.mData; |
108 | } | 108 | } |
109 | 109 | ||
110 | Addressee &Addressee::operator=( const Addressee &a ) | 110 | Addressee &Addressee::operator=( const Addressee &a ) |
111 | { | 111 | { |
112 | mData = a.mData; | 112 | mData = a.mData; |
113 | return (*this); | 113 | return (*this); |
114 | } | 114 | } |
115 | 115 | ||
116 | Addressee Addressee::copy() | 116 | Addressee Addressee::copy() |
117 | { | 117 | { |
118 | Addressee a; | 118 | Addressee a; |
119 | *(a.mData) = *mData; | 119 | *(a.mData) = *mData; |
120 | return a; | 120 | return a; |
121 | } | 121 | } |
122 | 122 | ||
123 | void Addressee::detach() | 123 | void Addressee::detach() |
124 | { | 124 | { |
125 | if ( mData.count() == 1 ) return; | 125 | if ( mData.count() == 1 ) return; |
126 | *this = copy(); | 126 | *this = copy(); |
127 | } | 127 | } |
128 | 128 | ||
129 | bool Addressee::operator==( const Addressee &a ) const | 129 | bool Addressee::operator==( const Addressee &a ) const |
130 | { | 130 | { |
131 | if ( uid() != a.uid() ) return false; | 131 | if ( uid() != a.uid() ) return false; |
132 | if ( mData->name != a.mData->name ) return false; | 132 | if ( mData->name != a.mData->name ) return false; |
133 | if ( mData->formattedName != a.mData->formattedName ) return false; | 133 | if ( mData->formattedName != a.mData->formattedName ) return false; |
134 | if ( mData->familyName != a.mData->familyName ) return false; | 134 | if ( mData->familyName != a.mData->familyName ) return false; |
135 | if ( mData->givenName != a.mData->givenName ) return false; | 135 | if ( mData->givenName != a.mData->givenName ) return false; |
136 | if ( mData->additionalName != a.mData->additionalName ) return false; | 136 | if ( mData->additionalName != a.mData->additionalName ) return false; |
137 | if ( mData->prefix != a.mData->prefix ) return false; | 137 | if ( mData->prefix != a.mData->prefix ) return false; |
138 | if ( mData->suffix != a.mData->suffix ) return false; | 138 | if ( mData->suffix != a.mData->suffix ) return false; |
139 | if ( mData->nickName != a.mData->nickName ) return false; | 139 | if ( mData->nickName != a.mData->nickName ) return false; |
140 | if ( mData->birthday != a.mData->birthday ) return false; | 140 | if ( mData->birthday != a.mData->birthday ) return false; |
141 | if ( mData->mailer != a.mData->mailer ) return false; | 141 | if ( mData->mailer != a.mData->mailer ) return false; |
142 | if ( mData->timeZone != a.mData->timeZone ) return false; | 142 | if ( mData->timeZone != a.mData->timeZone ) return false; |
143 | if ( mData->geo != a.mData->geo ) return false; | 143 | if ( mData->geo != a.mData->geo ) return false; |
144 | if ( mData->title != a.mData->title ) return false; | 144 | if ( mData->title != a.mData->title ) return false; |
145 | if ( mData->role != a.mData->role ) return false; | 145 | if ( mData->role != a.mData->role ) return false; |
146 | if ( mData->organization != a.mData->organization ) return false; | 146 | if ( mData->organization != a.mData->organization ) return false; |
147 | if ( mData->note != a.mData->note ) return false; | 147 | if ( mData->note != a.mData->note ) return false; |
148 | if ( mData->productId != a.mData->productId ) return false; | 148 | if ( mData->productId != a.mData->productId ) return false; |
149 | if ( mData->revision != a.mData->revision ) return false; | 149 | //if ( mData->revision != a.mData->revision ) return false; |
150 | if ( mData->sortString != a.mData->sortString ) return false; | 150 | if ( mData->sortString != a.mData->sortString ) return false; |
151 | if ( mData->secrecy != a.mData->secrecy ) return false; | 151 | if ( mData->secrecy != a.mData->secrecy ) return false; |
152 | if ( mData->logo != a.mData->logo ) return false; | 152 | if ( mData->logo != a.mData->logo ) return false; |
153 | if ( mData->photo != a.mData->photo ) return false; | 153 | if ( mData->photo != a.mData->photo ) return false; |
154 | if ( mData->sound != a.mData->sound ) return false; | 154 | if ( mData->sound != a.mData->sound ) return false; |
155 | if ( mData->agent != a.mData->agent ) return false; | 155 | if ( mData->agent != a.mData->agent ) return false; |
156 | if ( ( mData->url.isValid() || a.mData->url.isValid() ) && | 156 | if ( ( mData->url.isValid() || a.mData->url.isValid() ) && |
157 | ( mData->url != a.mData->url ) ) return false; | 157 | ( mData->url != a.mData->url ) ) return false; |
158 | if ( mData->phoneNumbers != a.mData->phoneNumbers ) return false; | 158 | if ( mData->phoneNumbers != a.mData->phoneNumbers ) return false; |
159 | if ( mData->addresses != a.mData->addresses ) return false; | 159 | if ( mData->addresses != a.mData->addresses ) return false; |
160 | if ( mData->keys != a.mData->keys ) return false; | 160 | if ( mData->keys != a.mData->keys ) return false; |
161 | if ( mData->emails != a.mData->emails ) return false; | 161 | if ( mData->emails != a.mData->emails ) return false; |
162 | if ( mData->categories != a.mData->categories ) return false; | 162 | if ( mData->categories != a.mData->categories ) return false; |
163 | if ( mData->custom != a.mData->custom ) return false; | 163 | if ( mData->custom != a.mData->custom ) return false; |
164 | 164 | ||
165 | return true; | 165 | return true; |
166 | } | 166 | } |
167 | 167 | ||
168 | bool Addressee::operator!=( const Addressee &a ) const | 168 | bool Addressee::operator!=( const Addressee &a ) const |
169 | { | 169 | { |
170 | return !( a == *this ); | 170 | return !( a == *this ); |
171 | } | 171 | } |
172 | 172 | ||
173 | bool Addressee::isEmpty() const | 173 | bool Addressee::isEmpty() const |
174 | { | 174 | { |
175 | return mData->empty; | 175 | return mData->empty; |
176 | } | 176 | } |
177 | ulong Addressee::getCsum4List( const QStringList & attList) | 177 | ulong Addressee::getCsum4List( const QStringList & attList) |
178 | { | 178 | { |
179 | int max = attList.count(); | 179 | int max = attList.count(); |
180 | ulong cSum = 0; | 180 | ulong cSum = 0; |
181 | int j,k,i; | 181 | int j,k,i; |
182 | int add; | 182 | int add; |
183 | for ( i = 0; i < max ; ++i ) { | 183 | for ( i = 0; i < max ; ++i ) { |
184 | QString s = attList[i]; | 184 | QString s = attList[i]; |
185 | if ( ! s.isEmpty() ){ | 185 | if ( ! s.isEmpty() ){ |
186 | j = s.length(); | 186 | j = s.length(); |
187 | for ( k = 0; k < j; ++k ) { | 187 | for ( k = 0; k < j; ++k ) { |
188 | int mul = k +1; | 188 | int mul = k +1; |
189 | add = s[k].unicode (); | 189 | add = s[k].unicode (); |
190 | if ( k < 16 ) | 190 | if ( k < 16 ) |
191 | mul = mul * mul; | 191 | mul = mul * mul; |
192 | int ii = i+1; | 192 | int ii = i+1; |
193 | add = add * mul *ii*ii*ii; | 193 | add = add * mul *ii*ii*ii; |
194 | cSum += add; | 194 | cSum += add; |
195 | } | 195 | } |
196 | } | 196 | } |
197 | 197 | ||
@@ -244,107 +244,114 @@ void Addressee::computeCsum(const QString &dev) | |||
244 | for ( phoneIter = mData->phoneNumbers.begin(); phoneIter != mData->phoneNumbers.end(); | 244 | for ( phoneIter = mData->phoneNumbers.begin(); phoneIter != mData->phoneNumbers.end(); |
245 | ++phoneIter ) | 245 | ++phoneIter ) |
246 | t.append( ( *phoneIter ).number()+QString::number( ( *phoneIter ).type() ) ); | 246 | t.append( ( *phoneIter ).number()+QString::number( ( *phoneIter ).type() ) ); |
247 | t.sort(); | 247 | t.sort(); |
248 | uint iii; | 248 | uint iii; |
249 | for ( iii = 0; iii < t.count(); ++iii) | 249 | for ( iii = 0; iii < t.count(); ++iii) |
250 | l.append( t[iii] ); | 250 | l.append( t[iii] ); |
251 | t = mData->emails; | 251 | t = mData->emails; |
252 | t.sort(); | 252 | t.sort(); |
253 | for ( iii = 0; iii < t.count(); ++iii) | 253 | for ( iii = 0; iii < t.count(); ++iii) |
254 | l.append( t[iii] ); | 254 | l.append( t[iii] ); |
255 | t = mData->categories; | 255 | t = mData->categories; |
256 | t.sort(); | 256 | t.sort(); |
257 | for ( iii = 0; iii < t.count(); ++iii) | 257 | for ( iii = 0; iii < t.count(); ++iii) |
258 | l.append( t[iii] ); | 258 | l.append( t[iii] ); |
259 | t = mData->custom; | 259 | t = mData->custom; |
260 | t.sort(); | 260 | t.sort(); |
261 | for ( iii = 0; iii < t.count(); ++iii) | 261 | for ( iii = 0; iii < t.count(); ++iii) |
262 | l.append( t[iii] ); | 262 | l.append( t[iii] ); |
263 | KABC::Address::List::Iterator addressIter; | 263 | KABC::Address::List::Iterator addressIter; |
264 | for ( addressIter = mData->addresses.begin(); addressIter != mData->addresses.end(); | 264 | for ( addressIter = mData->addresses.begin(); addressIter != mData->addresses.end(); |
265 | ++addressIter ) { | 265 | ++addressIter ) { |
266 | t = (*addressIter).asList(); | 266 | t = (*addressIter).asList(); |
267 | t.sort(); | 267 | t.sort(); |
268 | for ( iii = 0; iii < t.count(); ++iii) | 268 | for ( iii = 0; iii < t.count(); ++iii) |
269 | l.append( t[iii] ); | 269 | l.append( t[iii] ); |
270 | } | 270 | } |
271 | uint cs = getCsum4List(l); | 271 | uint cs = getCsum4List(l); |
272 | // qDebug("CSUM computed %d %s %s", cs,QString::number (cs ).latin1(), uid().latin1() ); | 272 | // qDebug("CSUM computed %d %s %s", cs,QString::number (cs ).latin1(), uid().latin1() ); |
273 | setCsum( dev, QString::number (cs )); | 273 | setCsum( dev, QString::number (cs )); |
274 | } | 274 | } |
275 | 275 | ||
276 | void Addressee::mergeContact( const Addressee& ad ) | 276 | void Addressee::mergeContact( const Addressee& ad ) |
277 | { | 277 | { |
278 | 278 | ||
279 | detach(); | 279 | detach(); |
280 | if ( mData->name.isEmpty() ) mData->name = ad.mData->name; | 280 | if ( mData->name.isEmpty() ) mData->name = ad.mData->name; |
281 | if ( mData->formattedName.isEmpty() ) mData->formattedName = ad.mData->formattedName; | 281 | if ( mData->formattedName.isEmpty() ) mData->formattedName = ad.mData->formattedName; |
282 | if ( mData->familyName.isEmpty() ) mData->familyName = ad.mData->familyName; | 282 | if ( mData->familyName.isEmpty() ) mData->familyName = ad.mData->familyName; |
283 | if ( mData->givenName.isEmpty() ) mData->givenName = ad.mData->givenName ; | 283 | if ( mData->givenName.isEmpty() ) mData->givenName = ad.mData->givenName ; |
284 | if ( mData->additionalName ) mData->additionalName = ad.mData->additionalName; | 284 | if ( mData->additionalName ) mData->additionalName = ad.mData->additionalName; |
285 | if ( mData->prefix.isEmpty() ) mData->prefix = ad.mData->prefix; | 285 | if ( mData->prefix.isEmpty() ) mData->prefix = ad.mData->prefix; |
286 | if ( mData->suffix.isEmpty() ) mData->suffix = ad.mData->suffix; | 286 | if ( mData->suffix.isEmpty() ) mData->suffix = ad.mData->suffix; |
287 | if ( mData->nickName.isEmpty() ) mData->nickName = ad.mData->nickName; | 287 | if ( mData->nickName.isEmpty() ) mData->nickName = ad.mData->nickName; |
288 | if ( !mData->birthday.isValid() ) | 288 | if ( !mData->birthday.isValid() ) |
289 | if ( ad.mData->birthday.isValid()) | 289 | if ( ad.mData->birthday.isValid()) |
290 | mData->birthday = ad.mData->birthday; | 290 | mData->birthday = ad.mData->birthday; |
291 | if ( mData->mailer.isEmpty() ) mData->mailer = ad.mData->mailer; | 291 | if ( mData->mailer.isEmpty() ) mData->mailer = ad.mData->mailer; |
292 | #if 0 | 292 | if ( !mData->timeZone.isValid() ) mData->timeZone = ad.mData->timeZone; |
293 | if ( !mData->timeZone.isValid() ) l.append( mData->timeZone.asString() ); | 293 | if ( !mData->geo.isValid() ) mData->geo = ad.mData->geo; |
294 | if ( mData->geo.isValid() ) l.append( mData->geo.asString() ); | 294 | if ( mData->title .isEmpty() ) mData->title = ad.mData->title ; |
295 | if ( !mData->title .isEmpty() ) l.append( mData->title ); | 295 | if ( mData->role.isEmpty() ) mData->role = ad.mData->role ; |
296 | if ( !mData->role.isEmpty() ) l.append( mData->role ); | 296 | if ( mData->organization.isEmpty() ) mData->organization = ad.mData->organization ; |
297 | if ( !mData->organization.isEmpty() ) l.append( mData->organization ); | 297 | if ( mData->note.isEmpty() ) mData->note = ad.mData->note ; |
298 | if ( !mData->note.isEmpty() ) l.append( mData->note ); | 298 | if ( mData->productId.isEmpty() ) mData->productId = ad.mData->productId; |
299 | if ( !mData->productId.isEmpty() ) l.append(mData->productId ); | 299 | if ( mData->sortString.isEmpty() ) mData->sortString = ad.mData->sortString; |
300 | if ( !mData->sortString.isEmpty() ) l.append( mData->sortString ); | 300 | if ( !mData->secrecy.isValid() ) mData->secrecy = ad.mData->secrecy; |
301 | if ( mData->secrecy.isValid() ) l.append( mData->secrecy.asString()); | 301 | if ( ( !mData->url.isValid() && ad.mData->url.isValid() ) ) mData->url = ad.mData->url ; |
302 | #endif | 302 | |
303 | // pending: | ||
304 | // merging phonenumbers | ||
305 | // merging addresses | ||
306 | // merging emails; | ||
307 | // merging categories; | ||
308 | // merging custom; | ||
309 | // merging keys | ||
303 | } | 310 | } |
304 | 311 | ||
305 | void Addressee::removeID(const QString &prof) | 312 | void Addressee::removeID(const QString &prof) |
306 | { | 313 | { |
307 | detach(); | 314 | detach(); |
308 | mData->mExternalId = KIdManager::removeId ( mData->mExternalId, prof); | 315 | mData->mExternalId = KIdManager::removeId ( mData->mExternalId, prof); |
309 | 316 | ||
310 | } | 317 | } |
311 | void Addressee::setID( const QString & prof , const QString & id ) | 318 | void Addressee::setID( const QString & prof , const QString & id ) |
312 | { | 319 | { |
313 | detach(); | 320 | detach(); |
314 | mData->mExternalId = KIdManager::setId ( mData->mExternalId, prof, id ); | 321 | mData->mExternalId = KIdManager::setId ( mData->mExternalId, prof, id ); |
315 | //qDebug("setID2 %s %s %s",mData->mExternalId.latin1(), prof.latin1(), id.latin1() ); | 322 | //qDebug("setID2 %s %s %s",mData->mExternalId.latin1(), prof.latin1(), id.latin1() ); |
316 | } | 323 | } |
317 | void Addressee::setTempSyncStat( int id ) | 324 | void Addressee::setTempSyncStat( int id ) |
318 | { | 325 | { |
319 | if ( mData->mTempSyncStat == id ) return; | 326 | if ( mData->mTempSyncStat == id ) return; |
320 | detach(); | 327 | detach(); |
321 | mData->mTempSyncStat = id; | 328 | mData->mTempSyncStat = id; |
322 | } | 329 | } |
323 | int Addressee::tempSyncStat() const | 330 | int Addressee::tempSyncStat() const |
324 | { | 331 | { |
325 | return mData->mTempSyncStat; | 332 | return mData->mTempSyncStat; |
326 | } | 333 | } |
327 | 334 | ||
328 | QString Addressee::getID( const QString & prof) | 335 | QString Addressee::getID( const QString & prof) |
329 | { | 336 | { |
330 | return KIdManager::getId ( mData->mExternalId, prof ); | 337 | return KIdManager::getId ( mData->mExternalId, prof ); |
331 | } | 338 | } |
332 | 339 | ||
333 | void Addressee::setCsum( const QString & prof , const QString & id ) | 340 | void Addressee::setCsum( const QString & prof , const QString & id ) |
334 | { | 341 | { |
335 | detach(); | 342 | detach(); |
336 | //qDebug("setcsum1 %s %s %s",mData->mExternalId.latin1(), prof.latin1(), id.latin1() ); | 343 | //qDebug("setcsum1 %s %s %s",mData->mExternalId.latin1(), prof.latin1(), id.latin1() ); |
337 | mData->mExternalId = KIdManager::setCsum ( mData->mExternalId, prof, id ); | 344 | mData->mExternalId = KIdManager::setCsum ( mData->mExternalId, prof, id ); |
338 | //qDebug("setcsum2 %s ",mData->mExternalId.latin1() ); | 345 | //qDebug("setcsum2 %s ",mData->mExternalId.latin1() ); |
339 | } | 346 | } |
340 | 347 | ||
341 | QString Addressee::getCsum( const QString & prof) | 348 | QString Addressee::getCsum( const QString & prof) |
342 | { | 349 | { |
343 | return KIdManager::getCsum ( mData->mExternalId, prof ); | 350 | return KIdManager::getCsum ( mData->mExternalId, prof ); |
344 | } | 351 | } |
345 | 352 | ||
346 | void Addressee::setIDStr( const QString & s ) | 353 | void Addressee::setIDStr( const QString & s ) |
347 | { | 354 | { |
348 | detach(); | 355 | detach(); |
349 | mData->mExternalId = s; | 356 | mData->mExternalId = s; |
350 | } | 357 | } |