aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/cal-util
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/cal-util')
-rw-r--r--calendar/cal-util/cal-component.c187
-rw-r--r--calendar/cal-util/cal-component.h22
2 files changed, 208 insertions, 1 deletions
diff --git a/calendar/cal-util/cal-component.c b/calendar/cal-util/cal-component.c
index 33ab5695cd..2ff980a0f6 100644
--- a/calendar/cal-util/cal-component.c
+++ b/calendar/cal-util/cal-component.c
@@ -84,6 +84,19 @@ typedef struct {
guint need_sequence_inc : 1;
} CalComponentPrivate;
+/* Private structure for alarms */
+struct _CalComponentAlarm {
+ /* Our parent component */
+ CalComponent *parent;
+
+ /* Alarm icalcomponent we wrap */
+ icalcomponent *icalcomp;
+
+ /* Properties */
+
+ icalproperty *action;
+};
+
static void cal_component_class_init (CalComponentClass *class);
@@ -503,7 +516,9 @@ scan_icalcomponent (CalComponent *comp)
prop = icalcomponent_get_next_property (priv->icalcomp, ICAL_ANY_PROPERTY))
scan_property (comp, prop);
- /* FIXME: parse ALARM subcomponents */
+ /* We don't scan for alarm subcomponents since they can be iterated
+ * through using cal_component_get_{first,next}_alarm().
+ */
}
/* Ensures that the mandatory calendar component properties (uid, dtstamp) do
@@ -2026,3 +2041,173 @@ cal_component_set_url (CalComponent *comp, const char *url)
icalcomponent_add_property (priv->icalcomp, priv->url);
}
}
+
+
+
+/* Scans an icalproperty from a calendar component and adds its mapping to our
+ * own alarm structure.
+ */
+static void
+scan_alarm_property (CalComponentAlarm *alarm, icalproperty *prop)
+{
+ icalproperty_kind kind;
+
+ kind = icalproperty_isa (prop);
+
+ switch (kind) {
+ case ICAL_ACTION_PROPERTY:
+ alarm->action = prop;
+ break;
+
+ default:
+ break;
+ }
+}
+
+/* Creates a CalComponentAlarm from a libical alarm subcomponent */
+static CalComponentAlarm *
+make_alarm (CalComponent *comp, icalcomponent *subcomp)
+{
+ CalComponentAlarm *alarm;
+ icalproperty *prop;
+
+ alarm = g_new (CalComponentAlarm, 1);
+
+ alarm->parent = comp;
+ alarm->icalcomp = subcomp;
+
+ for (prop = icalcomponent_get_first_property (subcomp, ICAL_ANY_PROPERTY);
+ prop;
+ prop = icalcomponent_get_next_property (subcomp, ICAL_ANY_PROPERTY))
+ scan_alarm_property (alarm, prop);
+
+ return alarm;
+}
+
+/**
+ * cal_component_get_first_alarm:
+ * @comp: A calendar component object.
+ *
+ * Starts an iterator for the alarms in a calendar component object. Subsequent
+ * alarms can be obtained with the cal_component_get_next_alarm() function.
+ *
+ * Return value: The first alarm in the component, or NULL if the component has
+ * no alarms. This should be freed using the cal_component_alarm_free()
+ * function.
+ **/
+CalComponentAlarm *
+cal_component_get_first_alarm (CalComponent *comp)
+{
+ CalComponentPrivate *priv;
+ icalcomponent *subcomp;
+
+ g_return_val_if_fail (comp != NULL, NULL);
+ g_return_val_if_fail (IS_CAL_COMPONENT (comp), NULL);
+
+ priv = comp->priv;
+ g_return_val_if_fail (priv->icalcomp != NULL, NULL);
+
+ subcomp = icalcomponent_get_first_component (priv->icalcomp, ICAL_VALARM_COMPONENT);
+ if (!subcomp)
+ return NULL;
+
+ return make_alarm (comp, subcomp);
+}
+
+/**
+ * cal_component_alarm_free:
+ * @alarm: A calendar alarm.
+ *
+ * Frees an alarm structure.
+ **/
+void
+cal_component_alarm_free (CalComponentAlarm *alarm)
+{
+ g_return_if_fail (alarm != NULL);
+
+ alarm->parent = NULL;
+ alarm->icalcomp = NULL;
+ alarm->action = NULL;
+
+ g_free (alarm);
+}
+
+/**
+ * cal_component_alarm_get_action:
+ * @alarm: An alarm.
+ * @action: Return value for the alarm's action type.
+ *
+ * Queries the action type of an alarm.
+ **/
+void
+cal_component_alarm_get_action (CalComponentAlarm *alarm, CalComponentAlarmAction *action)
+{
+ const char *str;
+
+ g_return_if_fail (alarm != NULL);
+ g_return_if_fail (action != NULL);
+
+ if (!alarm->action) {
+ *action = CAL_COMPONENT_ALARM_NONE;
+ return;
+ }
+
+ str = icalproperty_get_action (alarm->action);
+
+ if (strcasecmp (str, "AUDIO") == 0)
+ *action = CAL_COMPONENT_ALARM_AUDIO;
+ else if (strcasecmp (str, "DISPLAY") == 0)
+ *action = CAL_COMPONENT_ALARM_DISPLAY;
+ else if (strcasecmp (str, "EMAIL") == 0)
+ *action = CAL_COMPONENT_ALARM_EMAIL;
+ else if (strcasecmp (str, "PROCEDURE") == 0)
+ *action = CAL_COMPONENT_ALARM_PROCEDURE;
+ else
+ *action = CAL_COMPONENT_ALARM_UNKNOWN;
+}
+
+/**
+ * cal_component_alarm_set_action:
+ * @alarm: An alarm.
+ * @action: Action type.
+ *
+ * Sets the action type for an alarm.
+ **/
+void
+cal_component_alarm_set_action (CalComponentAlarm *alarm, CalComponentAlarmAction action)
+{
+ char *str;
+
+ g_return_if_fail (alarm != NULL);
+ g_return_if_fail (action != CAL_COMPONENT_ALARM_NONE);
+ g_return_if_fail (action != CAL_COMPONENT_ALARM_UNKNOWN);
+
+ switch (action) {
+ case CAL_COMPONENT_ALARM_AUDIO:
+ str = "AUDIO";
+ break;
+
+ case CAL_COMPONENT_ALARM_DISPLAY:
+ str = "DISPLAY";
+ break;
+
+ case CAL_COMPONENT_ALARM_EMAIL:
+ str = "EMAIL";
+ break;
+
+ case CAL_COMPONENT_ALARM_PROCEDURE:
+ str = "PROCEDURE";
+ break;
+
+ default:
+ g_assert_not_reached ();
+ str = NULL;
+ }
+
+ if (alarm->action)
+ icalproperty_set_action (alarm->action, str);
+ else {
+ alarm->action = icalproperty_new_action (str);
+ icalcomponent_add_property (alarm->icalcomp, alarm->action);
+ }
+}
diff --git a/calendar/cal-util/cal-component.h b/calendar/cal-util/cal-component.h
index d29fcc48c5..d226940586 100644
--- a/calendar/cal-util/cal-component.h
+++ b/calendar/cal-util/cal-component.h
@@ -84,6 +84,7 @@ typedef enum {
CAL_COMPONENT_TRANSP_UNKNOWN
} CalComponentTransparency;
+typedef struct _CalComponentAlarm CalComponentAlarm;
typedef struct _CalComponent CalComponent;
typedef struct _CalComponentClass CalComponentClass;
@@ -99,6 +100,8 @@ struct _CalComponentClass {
GtkObjectClass parent_class;
};
+/* Calendar component */
+
GtkType cal_component_get_type (void);
char *cal_component_gen_uid (void);
@@ -168,6 +171,25 @@ void cal_component_set_transparency (CalComponent *comp, CalComponentTransparenc
void cal_component_get_url (CalComponent *comp, const char **url);
void cal_component_set_url (CalComponent *comp, const char *url);
+/* Alarms */
+
+typedef enum {
+ CAL_COMPONENT_ALARM_NONE,
+ CAL_COMPONENT_ALARM_AUDIO,
+ CAL_COMPONENT_ALARM_DISPLAY,
+ CAL_COMPONENT_ALARM_EMAIL,
+ CAL_COMPONENT_ALARM_PROCEDURE,
+ CAL_COMPONENT_ALARM_UNKNOWN
+} CalComponentAlarmAction;
+
+CalComponentAlarm *cal_component_get_first_alarm (CalComponent *comp);
+CalComponentAlarm *cal_component_get_next_alarm (CalComponent *comp);
+
+void cal_component_alarm_free (CalComponentAlarm *alarm);
+
+void cal_component_alarm_get_action (CalComponentAlarm *alarm, CalComponentAlarmAction *action);
+void cal_component_alarm_set_action (CalComponentAlarm *alarm, CalComponentAlarmAction action);
+
END_GNOME_DECLS