e-cal-util

e-cal-util — Various utility functions.

Synopsis




            CalObjInstance;
void        cal_obj_instance_list_free      (GList *list);
enum        CalObjModType;
enum        CalMode;
void        cal_obj_uid_list_free           (GList *list);
icalcomponent* e_cal_util_new_top_level     (void);
icalcomponent* e_cal_util_parse_ics_file    (const char *filename);
ECalComponentAlarms* e_cal_util_generate_alarms_for_comp
                                            (ECalComponent *comp,
                                             time_t start,
                                             time_t end,
                                             ECalComponentAlarmAction *omit,
                                             ECalRecurResolveTimezoneFn resolve_tzid,
                                             gpointer user_data,
                                             icaltimezone *default_timezone);
int         e_cal_util_generate_alarms_for_list
                                            (GList *comps,
                                             time_t start,
                                             time_t end,
                                             ECalComponentAlarmAction *omit,
                                             GSList **comp_alarms,
                                             ECalRecurResolveTimezoneFn resolve_tzid,
                                             gpointer user_data,
                                             icaltimezone *default_timezone);
icaltimezone* e_cal_util_resolve_tzid       (const char *tzid,
                                             gpointer data);
char*       e_cal_util_priority_to_string   (int priority);
int         e_cal_util_priority_from_string (const char *string);
void        e_cal_util_add_timezones_from_component
                                            (icalcomponent *vcal_comp,
                                             icalcomponent *icalcomp);
gboolean    e_cal_util_component_is_instance
                                            (icalcomponent *icalcomp);
gboolean    e_cal_util_component_has_alarms (icalcomponent *icalcomp);
gboolean    e_cal_util_component_has_organizer
                                            (icalcomponent *icalcomp);
gboolean    e_cal_util_component_has_recurrences
                                            (icalcomponent *icalcomp);
gboolean    e_cal_util_component_has_rdates (icalcomponent *icalcomp);
gboolean    e_cal_util_component_has_rrules (icalcomponent *icalcomp);
gboolean    e_cal_util_event_dates_match    (icalcomponent *icalcomp1,
                                             icalcomponent *icalcomp2);
#define     CAL_STATIC_CAPABILITY_NO_ALARM_REPEAT
#define     CAL_STATIC_CAPABILITY_NO_AUDIO_ALARMS
#define     CAL_STATIC_CAPABILITY_NO_DISPLAY_ALARMS
#define     CAL_STATIC_CAPABILITY_NO_EMAIL_ALARMS
#define     CAL_STATIC_CAPABILITY_NO_PROCEDURE_ALARMS
#define     CAL_STATIC_CAPABILITY_NO_TASK_ASSIGNMENT
#define     CAL_STATIC_CAPABILITY_NO_THISANDFUTURE
#define     CAL_STATIC_CAPABILITY_NO_THISANDPRIOR
#define     CAL_STATIC_CAPABILITY_NO_TRANSPARENCY
#define     CAL_STATIC_CAPABILITY_ONE_ALARM_ONLY
#define     CAL_STATIC_CAPABILITY_ORGANIZER_MUST_ATTEND
#define     CAL_STATIC_CAPABILITY_ORGANIZER_NOT_EMAIL_ADDRESS
#define     CAL_STATIC_CAPABILITY_REMOVE_ALARMS
#define     CAL_STATIC_CAPABILITY_SAVE_SCHEDULES
icalcomponent* e_cal_util_construct_instance
                                            (icalcomponent *icalcomp,
                                             struct icaltimetype rid);
void        e_cal_util_remove_instances     (icalcomponent *icalcomp,
                                             struct icaltimetype rid,
                                             CalObjModType mod);

Description

Details

CalObjInstance

typedef struct {
	char *uid;			/* UID of the object */
	time_t start;			/* Start time of instance */
	time_t end;			/* End time of instance */
} CalObjInstance;


cal_obj_instance_list_free ()

void        cal_obj_instance_list_free      (GList *list);

Frees a list of CalObjInstance structures.

list : List of CalObjInstance structures.

enum CalObjModType

typedef enum {
	CALOBJ_MOD_THIS          = 1 << 0,
	CALOBJ_MOD_THISANDPRIOR  = 1 << 1,
	CALOBJ_MOD_THISANDFUTURE = 1 << 2,
	CALOBJ_MOD_ALL           = 0x07
} CalObjModType;


enum CalMode

typedef enum {
	CAL_MODE_INVALID = -1,
	CAL_MODE_LOCAL   = 1 << 0,
	CAL_MODE_REMOTE  = 1 << 1,
	CAL_MODE_ANY     = 0x07
} CalMode;


cal_obj_uid_list_free ()

void        cal_obj_uid_list_free           (GList *list);

Frees a list of unique identifiers for calendar objects.

list : List of strings with unique identifiers.

e_cal_util_new_top_level ()

icalcomponent* e_cal_util_new_top_level     (void);

Creates a new VCALENDAR component.

Returns : the newly created top level component.

e_cal_util_parse_ics_file ()

icalcomponent* e_cal_util_parse_ics_file    (const char *filename);

Parses the given file, and, if it contains a valid iCalendar object, parse it and return a corresponding icalcomponent.

filename : Name of the file to be parsed.
Returns : an icalcomponent.

e_cal_util_generate_alarms_for_comp ()

ECalComponentAlarms* e_cal_util_generate_alarms_for_comp
                                            (ECalComponent *comp,
                                             time_t start,
                                             time_t end,
                                             ECalComponentAlarmAction *omit,
                                             ECalRecurResolveTimezoneFn resolve_tzid,
                                             gpointer user_data,
                                             icaltimezone *default_timezone);

Generates alarm instances for a calendar component. Returns the instances structure, or NULL if no alarm instances occurred in the specified time range.

comp : The ECalComponent to generate alarms from.
start : Start time.
end : End time.
omit :
resolve_tzid : Callback for resolving timezones
user_data : Data to be passed to the resolve_tzid callback
default_timezone : The timezone used to resolve DATE and floating DATE-TIME values.
Returns : a list of all the alarms found for the given component on the given time tange. The list of alarms should be freed by using the e_cal_component_free_alarm_list function.

e_cal_util_generate_alarms_for_list ()

int         e_cal_util_generate_alarms_for_list
                                            (GList *comps,
                                             time_t start,
                                             time_t end,
                                             ECalComponentAlarmAction *omit,
                                             GSList **comp_alarms,
                                             ECalRecurResolveTimezoneFn resolve_tzid,
                                             gpointer user_data,
                                             icaltimezone *default_timezone);

Iterates through all the components in the comps list and generates alarm instances for them; putting them in the comp_alarms list.

comps : List of ECalComponent's.
start : Start time.
end : End time.
omit :
comp_alarms : List to be returned
resolve_tzid : Callback for resolving timezones
user_data : Data to be passed to the resolve_tzid callback
default_timezone : The timezone used to resolve DATE and floating DATE-TIME values.
Returns : the number of elements it added to the list.

e_cal_util_resolve_tzid ()

icaltimezone* e_cal_util_resolve_tzid       (const char *tzid,
                                             gpointer data);

tzid :
data :
Returns :

e_cal_util_priority_to_string ()

char*       e_cal_util_priority_to_string   (int priority);

Converts an iCalendar PRIORITY value to a translated string. Any unknown priority value (i.e. not 0-9) will be returned as "" (undefined).

priority : Priority value.
Returns : a string representing the PRIORITY value. This value is a constant, so it should never be freed.

e_cal_util_priority_from_string ()

int         e_cal_util_priority_from_string (const char *string);

Converts a translated priority string to an iCalendar priority value.

string : A string representing the PRIORITY value.
Returns : the priority (0-9) or -1 if the priority string is not valid.

e_cal_util_add_timezones_from_component ()

void        e_cal_util_add_timezones_from_component
                                            (icalcomponent *vcal_comp,
                                             icalcomponent *icalcomp);

Adds VTIMEZONE components to a VCALENDAR for all tzid's in the given icalcomp.

vcal_comp : A VCALENDAR component.
icalcomp : An iCalendar component, of any type.

e_cal_util_component_is_instance ()

gboolean    e_cal_util_component_is_instance
                                            (icalcomponent *icalcomp);

Checks whether an icalcomponent is an instance of a recurring appointment or not.

icalcomp : An icalcomponent.
Returns : TRUE if it is an instance, FALSE if not.

e_cal_util_component_has_alarms ()

gboolean    e_cal_util_component_has_alarms (icalcomponent *icalcomp);

Checks whether an icalcomponent has any alarm.

icalcomp : An icalcomponent.
Returns : TRUE if it has alarms, FALSE otherwise.

e_cal_util_component_has_organizer ()

gboolean    e_cal_util_component_has_organizer
                                            (icalcomponent *icalcomp);

Checks whether an icalcomponent has an organizer or not.

icalcomp : An icalcomponent.
Returns : TRUE if there is an organizer, FALSE if not.

e_cal_util_component_has_recurrences ()

gboolean    e_cal_util_component_has_recurrences
                                            (icalcomponent *icalcomp);

Checks if an icalcomponent has recurrence dates or rules.

icalcomp : An icalcomponent.
Returns : TRUE if there are recurrence dates/rules, FALSE if not.

e_cal_util_component_has_rdates ()

gboolean    e_cal_util_component_has_rdates (icalcomponent *icalcomp);

Checks if an icalcomponent has recurrence dates.

icalcomp : An icalcomponent.
Returns : TRUE if there are recurrence dates, FALSE if not.

e_cal_util_component_has_rrules ()

gboolean    e_cal_util_component_has_rrules (icalcomponent *icalcomp);

Checks if an icalcomponent has recurrence rules.

icalcomp : An icalcomponent.
Returns : TRUE if there are recurrence rules, FALSE if not.

e_cal_util_event_dates_match ()

gboolean    e_cal_util_event_dates_match    (icalcomponent *icalcomp1,
                                             icalcomponent *icalcomp2);

Compare the dates of two icalcomponent's to check if they match.

icalcomp1 : An icalcomponent.
icalcomp2 : An icalcomponent.
Returns : TRUE if the dates of both components match, FALSE otherwise.

CAL_STATIC_CAPABILITY_NO_ALARM_REPEAT

#define CAL_STATIC_CAPABILITY_NO_ALARM_REPEAT             "no-alarm-repeat"


CAL_STATIC_CAPABILITY_NO_AUDIO_ALARMS

#define CAL_STATIC_CAPABILITY_NO_AUDIO_ALARMS             "no-audio-alarms"


CAL_STATIC_CAPABILITY_NO_DISPLAY_ALARMS

#define CAL_STATIC_CAPABILITY_NO_DISPLAY_ALARMS           "no-display-alarms"


CAL_STATIC_CAPABILITY_NO_EMAIL_ALARMS

#define CAL_STATIC_CAPABILITY_NO_EMAIL_ALARMS             "no-email-alarms"


CAL_STATIC_CAPABILITY_NO_PROCEDURE_ALARMS

#define CAL_STATIC_CAPABILITY_NO_PROCEDURE_ALARMS         "no-procedure-alarms"


CAL_STATIC_CAPABILITY_NO_TASK_ASSIGNMENT

#define CAL_STATIC_CAPABILITY_NO_TASK_ASSIGNMENT          "no-task-assignment"


CAL_STATIC_CAPABILITY_NO_THISANDFUTURE

#define CAL_STATIC_CAPABILITY_NO_THISANDFUTURE            "no-thisandfuture"


CAL_STATIC_CAPABILITY_NO_THISANDPRIOR

#define CAL_STATIC_CAPABILITY_NO_THISANDPRIOR             "no-thisandprior"


CAL_STATIC_CAPABILITY_NO_TRANSPARENCY

#define CAL_STATIC_CAPABILITY_NO_TRANSPARENCY             "no-transparency"


CAL_STATIC_CAPABILITY_ONE_ALARM_ONLY

#define CAL_STATIC_CAPABILITY_ONE_ALARM_ONLY              "one-alarm-only"


CAL_STATIC_CAPABILITY_ORGANIZER_MUST_ATTEND

#define CAL_STATIC_CAPABILITY_ORGANIZER_MUST_ATTEND       "organizer-must-attend"


CAL_STATIC_CAPABILITY_ORGANIZER_NOT_EMAIL_ADDRESS

#define CAL_STATIC_CAPABILITY_ORGANIZER_NOT_EMAIL_ADDRESS "organizer-not-email-address"


CAL_STATIC_CAPABILITY_REMOVE_ALARMS

#define CAL_STATIC_CAPABILITY_REMOVE_ALARMS               "remove-alarms"


CAL_STATIC_CAPABILITY_SAVE_SCHEDULES

#define CAL_STATIC_CAPABILITY_SAVE_SCHEDULES              "save-schedules"


e_cal_util_construct_instance ()

icalcomponent* e_cal_util_construct_instance
                                            (icalcomponent *icalcomp,
                                             struct icaltimetype rid);

This checks that rid indicates a valid recurrence of icalcomp, and if so, generates a copy of comp containing a RECURRENCE-ID of rid.

icalcomp : A recurring icalcomponent
rid : The RECURRENCE-ID to construct a component for
Returns : the instance, or NULL.

e_cal_util_remove_instances ()

void        e_cal_util_remove_instances     (icalcomponent *icalcomp,
                                             struct icaltimetype rid,
                                             CalObjModType mod);

Removes one or more instances from comp according to rid and mod.

FIXME: should probably have a return value indicating whether or not icalcomp still has any instances

icalcomp : A (recurring) icalcomponent
rid : The base RECURRENCE-ID to remove
mod : How to interpret rid