]> git.0d.be Git - empathy.git/commitdiff
Fix crash when displaying google account vcard
authorXavier Claessens <xavier.claessens@collabora.co.uk>
Tue, 7 May 2013 13:14:48 +0000 (15:14 +0200)
committerXavier Claessens <xavier.claessens@collabora.co.uk>
Tue, 7 May 2013 13:24:04 +0000 (15:24 +0200)
libempathy-gtk/empathy-user-info.c

index 4c9a2deee7f62207c0f2b4392a59aeb6fc8518ca..77b0798f26c5194bfc78c389d91550f65515cd0c 100644 (file)
@@ -192,6 +192,17 @@ fill_contact_info_grid (EmpathyUserInfo *self)
     {
       TpContactInfoField *field = l->data;
 
     {
       TpContactInfoField *field = l->data;
 
+      /* For some reason it can happen that the vCard contains fields the CM
+       * claims to be not supported. This is a workaround for gabble bug
+       * https://bugs.freedesktop.org/show_bug.cgi?id=64319. But we shouldn't
+       * crash on buggy CM anyway. */
+      if (get_spec_from_list (specs, field->field_name) == NULL)
+        {
+          DEBUG ("Buggy CM: self's vCard contains %s field but it is not in "
+              "Connection' supported fields", field->field_name);
+          continue;
+        }
+
       /* make a copy for the details_to_set list */
       field = tp_contact_info_field_copy (field);
       DEBUG ("Field %s is in our vCard", field->field_name);
       /* make a copy for the details_to_set list */
       field = tp_contact_info_field_copy (field);
       DEBUG ("Field %s is in our vCard", field->field_name);