/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ #include #include #include "e-contact-list-model.h" #include "e-util/e-error.h" #include #define PARENT_TYPE e_table_model_get_type() static ETableModelClass *parent_class; #define COLS 1 /* This function returns the number of columns in our ETableModel. */ static int contact_list_col_count (ETableModel *etc) { return COLS; } /* This function returns the number of rows in our ETableModel. */ static int contact_list_row_count (ETableModel *etc) { EContactListModel *model = E_CONTACT_LIST_MODEL (etc); return model->data_count; } /* This function returns the value at a particular point in our ETableModel. */ static void * contact_list_value_at (ETableModel *etc, int col, int row) { EContactListModel *model = E_CONTACT_LIST_MODEL (etc); return (void *) e_destination_get_textrep (model->data[row], TRUE); } /* This function sets the value at a particular point in our ETableModel. */ static void contact_list_set_value_at (ETableModel *etc, int col, int row, const void *val) { /* nothing */ } /* This function returns whether a particular cell is editable. */ static gboolean contact_list_is_cell_editable (ETableModel *etc, int col, int row) { return FALSE; } /* This function duplicates the value passed to it. */ static void * contact_list_duplicate_value (ETableModel *etc, int col, const void *value) { return g_strdup(value); } /* This function frees the value passed to it. */ static void contact_list_free_value (ETableModel *etc, int col, void *value) { g_free(value); } static void * contact_list_initialize_value (ETableModel *etc, int col) { return g_strdup(""); } static gboolean contact_list_value_is_empty (ETableModel *etc, int col, const void *value) { return !(value && *(char *)value); } static char * contact_list_value_to_string (ETableModel *etc, int col, const void *value) { return g_strdup(value); } static void contact_list_model_dispose (GObject *o) { EContactListModel *model = E_CONTACT_LIST_MODEL (o); int i; if (model->data != NULL) { for (i = 0; i < model->data_count; i ++) { g_object_unref (model->data[i]); } g_free (model->data); model->data = NULL; } model->data_count = 0; model->data_alloc = 0; (* G_OBJECT_CLASS (parent_class)->dispose) (o); } static void e_contact_list_model_class_init (GObjectClass *object_class) { ETableModelClass *model_class = (ETableModelClass *) object_class; parent_class = g_type_class_ref (PARENT_TYPE); object_class->dispose = contact_list_model_dispose; model_class->column_count = contact_list_col_count; model_class->row_count = contact_list_row_count; model_class->value_at = contact_list_value_at; model_class->set_value_at = contact_list_set_value_at; model_class->is_cell_editable = contact_list_is_cell_editable; model_class->duplicate_value = contact_list_duplicate_value; model_class->free_value = contact_list_free_value; model_class->initialize_value = contact_list_initialize_value; model_class->value_is_empty = contact_list_value_is_empty; model_class->value_to_string = contact_list_value_to_string; } static void e_contact_list_model_init (GObject *object) { EContactListModel *model = E_CONTACT_LIST_MODEL(object); model->data_alloc = 10; model->data_count = 0; model->data = g_new (EDestination*, model->data_alloc); } GType e_contact_list_model_get_type (void) { static GType cle_type = 0; if (!cle_type) { static const GTypeInfo cle_info = { sizeof (EContactListModelClass), NULL, /* base_init */ NULL, /* base_finalize */ (GClassInitFunc) e_contact_list_model_class_init, NULL, /* class_finalize */ NULL, /* class_data */ sizeof (EContactListModel), 0, /* n_preallocs */ (GInstanceInitFunc) e_contact_list_model_init, }; cle_type = g_type_register_static (E_TABLE_MODEL_TYPE, "EContactListModel", &cle_info, 0); } return cle_type; } void e_contact_list_model_construct (EContactListModel *model) { } ETableModel * e_contact_list_model_new (void) { EContactListModel *model; model = g_object_new (E_TYPE_CONTACT_LIST_MODEL, NULL); e_contact_list_model_construct (model); return E_TABLE_MODEL(model); } void e_contact_list_model_add_destination (EContactListModel *model, EDestination *dest) { g_return_if_fail (E_IS_CONTACT_LIST_MODEL (model)); g_return_if_fail (E_IS_DESTINATION (dest)); e_table_model_pre_change (E_TABLE_MODEL (model)); if (model->data_count + 1 >= model->data_alloc) { model->data_alloc *= 2; model->data = g_renew (EDestination*, model->data, model->data_alloc); } model->data[model->data_count ++] = dest; g_object_ref (dest); e_table_model_row_inserted (E_TABLE_MODEL (model), model->data_count - 1); } void e_contact_list_model_add_email (EContactListModel *model, const char *email) { EDestination *new_dest; char *list_email; int row; int row_count; g_return_if_fail (E_IS_CONTACT_LIST_MODEL (model)); g_return_if_fail (email != NULL); row_count = e_table_model_row_count (E_TABLE_MODEL (model)); for (row = 0; row < row_count; row++) { list_email = (char *) e_table_model_value_at (E_TABLE_MODEL (model), 1, row); if (strcmp (list_email, email) == 0) { if (e_error_run (NULL, "addressbook:ask-list-add-exists", email) != GTK_RESPONSE_YES) return; break; } } new_dest = e_destination_new (); e_destination_set_email (new_dest, email); e_contact_list_model_add_destination (model, new_dest); } void e_contact_list_model_add_contact (EContactListModel *model, EContact *contact, int email_num) { EDestination *new_dest; g_return_if_fail (E_IS_CONTACT_LIST_MODEL (model)); g_return_if_fail (E_IS_CONTACT (contact)); new_dest = e_destination_new (); e_destination_set_contact (new_dest, contact, email_num); e_contact_list_model_add_destination (model, new_dest); } void e_contact_list_model_remove_row (EContactListModel *model, int row) { g_return_if_fail (E_IS_CONTACT_LIST_MODEL (model)); g_return_if_fail (0 <= row && row < model->data_count); e_table_model_pre_change (E_TABLE_MODEL (model)); g_object_unref (model->data[row]); memmove (model->data + row, model->data + row + 1, sizeof (EDestination*) * (model->data_count - row - 1)); model->data_count --; e_table_model_row_deleted (E_TABLE_MODEL (model), row); } void e_contact_list_model_remove_all (EContactListModel *model) { int i; g_return_if_fail (E_IS_CONTACT_LIST_MODEL (model)); e_table_model_pre_change (E_TABLE_MODEL (model)); for (i = 0; i < model->data_count; i ++) { g_object_unref (model->data[i]); model->data[i] = NULL; } model->data_count = 0; e_table_model_changed (E_TABLE_MODEL (model)); } const EDestination * e_contact_list_model_get_destination (EContactListModel *model, int row) { g_return_val_if_fail (E_IS_CONTACT_LIST_MODEL (model), NULL); g_return_val_if_fail (0 <= row && row < model->data_count, NULL); return model->data[row]; }