diff options
Diffstat (limited to 'calendar')
-rw-r--r-- | calendar/ChangeLog | 7 | ||||
-rw-r--r-- | calendar/gui/Makefile.am | 2 | ||||
-rw-r--r-- | calendar/gui/calendar-model.c | 322 | ||||
-rw-r--r-- | calendar/gui/gnome-cal.c | 3 |
4 files changed, 309 insertions, 25 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog index bd4d231fde..2fa8922baa 100644 --- a/calendar/ChangeLog +++ b/calendar/ChangeLog @@ -1,3 +1,10 @@ +2000-06-26 Federico Mena Quintero <federico@helixcode.com> + + * gui/calendar-model.c (calendar_model_duplicate_value): + Implement. + (calendar_model_initialize_value): Implement. + (calendar_model_value_is_empty): Implement. + 2000-06-21 Damon Chaplin <damon@helixcode.com> * gui/e-day-view.c (e_day_view_reshape_long_event): set event before diff --git a/calendar/gui/Makefile.am b/calendar/gui/Makefile.am index 219003d780..5920d2112e 100644 --- a/calendar/gui/Makefile.am +++ b/calendar/gui/Makefile.am @@ -47,6 +47,8 @@ evolution_calendar_SOURCES = \ alarm.h \ calendar-commands.c \ calendar-commands.h \ + calendar-model.c \ + calendar-model.h \ control-factory.c \ control-factory.h \ component-factory.c \ diff --git a/calendar/gui/calendar-model.c b/calendar/gui/calendar-model.c index 49fefbcdd4..19cf7c27dd 100644 --- a/calendar/gui/calendar-model.c +++ b/calendar/gui/calendar-model.c @@ -56,20 +56,17 @@ static void calendar_model_free_value (ETableModel *etm, int col, void *value); static void *calendar_model_initialize_value (ETableModel *etm, int col); static gboolean calendar_model_value_is_empty (ETableModel *etm, int col, const void *value); -static void calendar_model_freeze (ETableModel *etm); -static void calendar_model_thaw (ETableModel *etm); - static ETableModelClass *parent_class; /** * calendar_model_get_type: - * @void: - * + * @void: + * * Registers the #CalendarModel class if necessary, and returns the type ID * associated to it. - * + * * Return value: The type ID of the #CalendarModel class. **/ GtkType @@ -115,11 +112,9 @@ calendar_model_class_init (CalendarModelClass *class) etm_class->set_value_at = calendar_model_set_value_at; etm_class->is_cell_editable = calendar_model_is_cell_editable; etm_class->duplicate_value = calendar_model_duplicate_value; -#if 0 etm_class->free_value = calendar_model_free_value; etm_class->initialize_value = calendar_model_initialize_value; etm_class->value_is_empty = calendar_model_value_is_empty; -#endif } /* Object initialization function for the calendar table model */ @@ -310,7 +305,7 @@ calendar_model_value_at (ETableModel *etm, int col, int row) /* Replaces a string */ static void -set_string (char **dest, char *value) +set_string (char **dest, const char *value) { if (*dest) g_free (*dest); @@ -323,28 +318,28 @@ set_string (char **dest, char *value) /* Replaces a time_t value */ static void -set_time_t (time_t *dest, time_t *value) +set_time_t (time_t *dest, const time_t *value) { *dest = *value; } /* Replaces a geo value */ static void -set_geo (iCalGeo *dest, iCalGeo *value) +set_geo (iCalGeo *dest, const iCalGeo *value) { *dest = *value; } /* Replaces a person value */ static void -set_person (iCalPerson *dest, iCalPerson *value) +set_person (iCalPerson **dest, const iCalPerson *value) { /* FIXME */ } /* Sets an int value */ static void -set_int (int *dest, int *value) +set_int (int *dest, const int *value) { *dest = *value; } @@ -368,7 +363,7 @@ calendar_model_set_value_at (ETableModel *etm, int col, int row, const void *val switch (col) { case ICAL_OBJECT_FIELD_COMMENT: - set_string (&ico->comment); + set_string (&ico->comment, value); break; case ICAL_OBJECT_FIELD_COMPLETED: @@ -400,7 +395,7 @@ calendar_model_set_value_at (ETableModel *etm, int col, int row, const void *val break; case ICAL_OBJECT_FIELD_LAST_MOD: - set_time (&ico->last_mod, value); + set_time_t (&ico->last_mod, value); break; case ICAL_OBJECT_FIELD_LOCATION: @@ -450,8 +445,8 @@ calendar_model_is_cell_editable (ETableModel *etm, int col, int row) model = CALENDAR_MODEL (etm); priv = model->priv; - g_return_val_if_fail (col >= 0 && col < ICAL_OBJECT_FIELD_NUM_FIELDS, NULL); - g_return_val_if_fail (row >= 0 && row < priv->objects->len, NULL); + g_return_val_if_fail (col >= 0 && col < ICAL_OBJECT_FIELD_NUM_FIELDS, FALSE); + g_return_val_if_fail (row >= 0 && row < priv->objects->len, FALSE); switch (col) { case ICAL_OBJECT_FIELD_HAS_ALARMS: @@ -462,52 +457,331 @@ calendar_model_is_cell_editable (ETableModel *etm, int col, int row) } } +/* Duplicates a string value */ +static char * +dup_string (const char *value) +{ + return g_strdup (value); +} + +/* Duplicates a time_t value */ +static time_t * +dup_time_t (const time_t *value) +{ + time_t *t; + + t = g_new (time_t, 1); + *t = *value; + return t; +} + +/* Duplicates a geo value */ +static iCalGeo * +dup_geo (const iCalGeo *value) +{ + iCalGeo *geo; + + geo = g_new (iCalGeo, 1); + *geo = *value; + return geo; +} + +/* Duplicates a person value */ +static iCalPerson * +dup_person (const iCalPerson *value) +{ + /* FIXME */ + return NULL; +} + +/* Duplicates an int value */ +static int * +dup_int (const int *value) +{ + int *v; + + v = g_new (int, 1); + *v = *value; + return v; +} + /* duplicate_value handler for the calendar table model */ static void * calendar_model_duplicate_value (ETableModel *etm, int col, const void *value) { - CalendarModel *model; - CalendarModelPrivate *priv; + g_return_val_if_fail (col >= 0 && col < ICAL_OBJECT_FIELD_NUM_FIELDS, NULL); - model = CALENDAR_MODEL (etm); - priv = model->priv; + switch (col) { + case ICAL_OBJECT_FIELD_COMMENT: + return dup_string (value); + + case ICAL_OBJECT_FIELD_COMPLETED: + return dup_time_t (value); + + case ICAL_OBJECT_FIELD_CREATED: + return dup_time_t (value); + + case ICAL_OBJECT_FIELD_DESCRIPTION: + return dup_string (value); + + case ICAL_OBJECT_FIELD_DTSTAMP: + return dup_time_t (value); + + case ICAL_OBJECT_FIELD_DTSTART: + return dup_time_t (value); + + case ICAL_OBJECT_FIELD_DTEND: + return dup_time_t (value); + + case ICAL_OBJECT_FIELD_GEO: + return dup_geo (value); + + case ICAL_OBJECT_FIELD_LAST_MOD: + return dup_time_t (value); + + case ICAL_OBJECT_FIELD_LOCATION: + return dup_string (value); + + case ICAL_OBJECT_FIELD_ORGANIZER: + return dup_person (value); + + case ICAL_OBJECT_FIELD_PERCENT: + return dup_int (value); + + case ICAL_OBJECT_FIELD_PRIORITY: + return dup_int (value); + + case ICAL_OBJECT_FIELD_SUMMARY: + return dup_string (value); + + case ICAL_OBJECT_FIELD_URL: + return dup_string (value); + + case ICAL_OBJECT_FIELD_HAS_ALARMS: + return (void *) value; + + default: + g_message ("calendar_model_duplicate_value(): Requested invalid column %d", col); + return NULL; + } +} + +/* free_value handler for the calendar table model */ +static void +calendar_model_free_value (ETableModel *etm, int col, void *value) +{ + g_return_if_fail (col >= 0 && col < ICAL_OBJECT_FIELD_NUM_FIELDS); + g_return_if_fail (value != NULL); + + /* FIXME: this requires special handling for iCalPerson */ + g_free (value); +} + +/* Initializes a string value */ +static char * +init_string (void) +{ + return g_strdup (""); +} + +/* Initializes a time_t value */ +static time_t * +init_time_t (void) +{ + time_t *t; + + t = g_new (time_t, 1); + *t = -1; + return t; +} + +/* Initializes a geo value */ +static iCalGeo * +init_geo (void) +{ + iCalGeo *geo; + geo = g_new (iCalGeo, 1); + geo->valid = FALSE; + geo->latitude = 0.0; + geo->longitude = 0.0; + return geo; +} + +/* Initializes a person value */ +static iCalPerson * +init_person (void) +{ + /* FIXME */ + return NULL; +} + +/* Initializes an int value */ +static int * +init_int (void) +{ + int *v; + + v = g_new (int, 1); + *v = 0; + return v; +} + +/* initialize_value handler for the calendar table model */ +static void * +calendar_model_initialize_value (ETableModel *etm, int col) +{ g_return_val_if_fail (col >= 0 && col < ICAL_OBJECT_FIELD_NUM_FIELDS, NULL); switch (col) { case ICAL_OBJECT_FIELD_COMMENT: + return init_string (); + + case ICAL_OBJECT_FIELD_COMPLETED: + return init_time_t (); + + case ICAL_OBJECT_FIELD_CREATED: + return init_time_t (); + + case ICAL_OBJECT_FIELD_DESCRIPTION: + return init_string (); + + case ICAL_OBJECT_FIELD_DTSTAMP: + return init_time_t (); + + case ICAL_OBJECT_FIELD_DTSTART: + return init_time_t (); + + case ICAL_OBJECT_FIELD_DTEND: + return init_time_t (); + + case ICAL_OBJECT_FIELD_GEO: + return init_geo (); + + case ICAL_OBJECT_FIELD_LAST_MOD: + return init_time_t (); + + case ICAL_OBJECT_FIELD_LOCATION: + return init_string (); + + case ICAL_OBJECT_FIELD_ORGANIZER: + return init_person (); + + case ICAL_OBJECT_FIELD_PERCENT: + return init_int (); + + case ICAL_OBJECT_FIELD_PRIORITY: + return init_int (); + + case ICAL_OBJECT_FIELD_SUMMARY: + return init_string (); + + case ICAL_OBJECT_FIELD_URL: + return init_string (); + + case ICAL_OBJECT_FIELD_HAS_ALARMS: + return NULL; /* "false" */ + + default: + g_message ("calendar_model_initialize_value(): Requested invalid column %d", col); + return NULL; + } +} + +/* Returns whether a string is empty */ +static gboolean +string_is_empty (const char *str) +{ + return !(str && *str); +} + +/* Returns whether a time_t is empty */ +static gboolean +time_t_is_empty (const time_t *t) +{ + return (*t == -1); +} + +/* Returns whether a geo is empty */ +static gboolean +geo_is_empty (const iCalGeo *geo) +{ + return !geo->valid; +} + +/* Returns whether a person is empty */ +static gboolean +person_is_empty (const iCalPerson *person) +{ + /* FIXME */ + return TRUE; +} + +/* Returns whether an int is empty */ +static gboolean +int_is_empty (const int *value) +{ + return FALSE; +} + +/* value_is_empty handler for the calendar model */ +static gboolean +calendar_model_value_is_empty (ETableModel *etm, int col, const void *value) +{ + g_return_val_if_fail (col >= 0 && col < ICAL_OBJECT_FIELD_NUM_FIELDS, TRUE); + + switch (col) { + case ICAL_OBJECT_FIELD_COMMENT: + return string_is_empty (value); case ICAL_OBJECT_FIELD_COMPLETED: + return time_t_is_empty (value); case ICAL_OBJECT_FIELD_CREATED: + return time_t_is_empty (value); case ICAL_OBJECT_FIELD_DESCRIPTION: + return string_is_empty (value); case ICAL_OBJECT_FIELD_DTSTAMP: + return time_t_is_empty (value); case ICAL_OBJECT_FIELD_DTSTART: + return time_t_is_empty (value); case ICAL_OBJECT_FIELD_DTEND: + return time_t_is_empty (value); case ICAL_OBJECT_FIELD_GEO: + return geo_is_empty (value); case ICAL_OBJECT_FIELD_LAST_MOD: + return time_t_is_empty (value); case ICAL_OBJECT_FIELD_LOCATION: + return string_is_empty (value); case ICAL_OBJECT_FIELD_ORGANIZER: + return person_is_empty (value); case ICAL_OBJECT_FIELD_PERCENT: + return int_is_empty (value); case ICAL_OBJECT_FIELD_PRIORITY: + return int_is_empty (value); case ICAL_OBJECT_FIELD_SUMMARY: + return string_is_empty (value); case ICAL_OBJECT_FIELD_URL: + return string_is_empty (value); case ICAL_OBJECT_FIELD_HAS_ALARMS: + return FALSE; default: + g_message ("calendar_model_value_is_empty(): Requested invalid column %d", col); + return TRUE; } } @@ -515,10 +789,10 @@ calendar_model_duplicate_value (ETableModel *etm, int col, const void *value) /** * calendar_model_new: - * + * * Creates a new calendar model. It must be told about the calendar client * interface object it will monitor with calendar_model_set_cal_client(). - * + * * Return value: A newly-created calendar model. **/ CalendarModel * @@ -734,7 +1008,7 @@ load_objects (CalendarModel *model) * @model: A calendar model. * @client: A calendar client interface object. * @type: Type of objects to present. - * + * * Sets the calendar client interface object that a calendar model will monitor. * It also sets the types of objects this model will present to an #ETable. **/ diff --git a/calendar/gui/gnome-cal.c b/calendar/gui/gnome-cal.c index 1e98737098..6291cd67cd 100644 --- a/calendar/gui/gnome-cal.c +++ b/calendar/gui/gnome-cal.c @@ -3,7 +3,8 @@ * GnomeCalendar widget * Copyright (C) 1998 the Free Software Foundation * - * Author: Miguel de Icaza (miguel@kernel.org) + * Authors: Miguel de Icaza (miguel@kernel.org) + * Federico Mena-Quintero <federico@helixcode.com> */ #include <config.h> |