It has been replaced by empathy_ensure_individual_from_tp_contact(),
which can’t cause internal state corruption in libfolks by wrapping an
existing Persona in a second Individual when it’s already wrapped in
one.
This has also been fixed in libfolks.
See: https://bugzilla.redhat.com/show_bug.cgi?id=
1031252
https://bugzilla.gnome.org/show_bug.cgi?id=712839
/* another request has been started */
goto out;
- individual = empathy_create_individual_from_tp_contact (contact);
+ individual = empathy_ensure_individual_from_tp_contact (contact);
if (individual == NULL)
goto out;
goto while_finish;
contact = empathy_contact_dup_from_tp_contact (tp_contact);
- single_individual = empathy_create_individual_from_tp_contact (
+ single_individual = empathy_ensure_individual_from_tp_contact (
tp_contact);
/* Pretty hacky. Creating single_individual had a side effect to change
if (g_hash_table_lookup (self->priv->individuals, contact) != NULL)
continue;
- individual = empathy_create_individual_from_tp_contact (contact);
+ individual = empathy_ensure_individual_from_tp_contact (contact);
if (individual == NULL)
return;
return individual;
}
-FolksIndividual *
-empathy_create_individual_from_tp_contact (TpContact *contact)
-{
- TpfPersona *persona;
- FolksIndividual *individual;
-
- persona = tpf_persona_dup_for_contact (contact);
- if (persona == NULL)
- {
- DEBUG ("Failed to get a persona for %s",
- tp_contact_get_identifier (contact));
- return NULL;
- }
-
- individual = create_individual_from_persona (FOLKS_PERSONA (persona));
-
- g_object_unref (persona);
- return individual;
-}
-
/* Look for a FolksIndividual containing @contact as one of his persona
* and create one if needed */
FolksIndividual *
gboolean empathy_client_types_contains_mobile_device (
const GStrv types);
-FolksIndividual * empathy_create_individual_from_tp_contact (
- TpContact *contact);
-
FolksIndividual * empathy_ensure_individual_from_tp_contact (
TpContact *contact);