diff options
Diffstat (limited to 'addressbook/gui/component/select-names/e-select-names-model.c')
-rw-r--r-- | addressbook/gui/component/select-names/e-select-names-model.c | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/addressbook/gui/component/select-names/e-select-names-model.c b/addressbook/gui/component/select-names/e-select-names-model.c index 6e0482ade3..66d7e96bb4 100644 --- a/addressbook/gui/component/select-names/e-select-names-model.c +++ b/addressbook/gui/component/select-names/e-select-names-model.c @@ -465,6 +465,22 @@ disconnect_destination (ESelectNamesModel *model, EDestination *dest) gtk_signal_disconnect_by_func (GTK_OBJECT (dest), destination_changed_proxy, model); } +gboolean +e_select_names_model_contains (ESelectNamesModel *model, EDestination *dest) +{ + GList *iter; + + g_return_val_if_fail (E_IS_SELECT_NAMES_MODEL (model), FALSE); + g_return_val_if_fail (E_IS_DESTINATION (dest), FALSE); + + for (iter = model->priv->data; iter != NULL; iter = g_list_next (iter)) { + if (iter->data != NULL && e_destination_equal (dest, E_DESTINATION (iter->data))) + return TRUE; + } + + return FALSE; +} + void e_select_names_model_insert (ESelectNamesModel *model, gint index, EDestination *dest) { @@ -652,6 +668,25 @@ e_select_names_model_overwrite_copy (ESelectNamesModel *dest, ESelectNamesModel } void +e_select_names_model_merge (ESelectNamesModel *dest, ESelectNamesModel *src) +{ + gint i, len; + + g_return_if_fail (E_IS_SELECT_NAMES_MODEL (dest)); + g_return_if_fail (E_IS_SELECT_NAMES_MODEL (src)); + + if (src == dest) + return; + + len = e_select_names_model_count (src); + for (i = 0; i < len; ++i) { + const EDestination *d = e_select_names_model_get_destination (src, i); + if (d && !e_select_names_model_contains (dest, d)) + e_select_names_model_append (dest, e_destination_copy (d)); + } +} + +void e_select_names_model_name_pos (ESelectNamesModel *model, gint index, gint *pos, gint *length) { gint rp = 0, i, len = 0; |