diff options
Diffstat (limited to 'calendar')
-rw-r--r-- | calendar/ChangeLog | 10 | ||||
-rw-r--r-- | calendar/gui/calendar-component.c | 38 | ||||
-rw-r--r-- | calendar/gui/component-factory.c | 38 |
3 files changed, 84 insertions, 2 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog index 4d74592553..fd0ca261b9 100644 --- a/calendar/ChangeLog +++ b/calendar/ChangeLog @@ -1,3 +1,13 @@ +2001-07-22 Ettore Perazzoli <ettore@ximian.com> + + * gui/component-factory.c (get_local_file_name_for_folder_type): + New helper function. + (remove_folder): Add a @type arg and handle it, by deleting + "tasks.ics" instead of "calendar.ics" if the type is "tasks". If + the type is not "tasks" or "calendar", report an + `UNSUPPORTED_TYPE' error. + (xfer_folder): Likewise. + 2001-07-21 Ettore Perazzoli <ettore@ximian.com> * gui/component-factory.c: Make folders of type "calendar" and diff --git a/calendar/gui/calendar-component.c b/calendar/gui/calendar-component.c index dd161a46dc..4b47fe697d 100644 --- a/calendar/gui/calendar-component.c +++ b/calendar/gui/calendar-component.c @@ -53,6 +53,20 @@ static const EvolutionShellComponentFolderType folder_types[] = { }; +/* Utility functions. */ + +static const char * +get_local_file_name_for_folder_type (const char *type) +{ + if (strcmp (type, "calendar") == 0) + return "calendar.ics"; + else if (strcmp (type, "tasks") == 0) + return "tasks.ics"; + else + return NULL; +} + + /* EvolutionShellComponent methods and signals. */ static EvolutionShellComponentResult @@ -107,10 +121,12 @@ create_folder (EvolutionShellComponent *shell_component, static void remove_folder (EvolutionShellComponent *shell_component, const char *physical_uri, + const char *type, const GNOME_Evolution_ShellComponentListener listener, void *closure) { CORBA_Environment ev; + const char *file_name; gchar *path; int rv; @@ -128,8 +144,17 @@ remove_folder (EvolutionShellComponent *shell_component, /* FIXME: check if there are subfolders? */ + file_name = get_local_file_name_for_folder_type (type); + if (file_name == NULL) { + GNOME_Evolution_ShellComponentListener_notifyResult (listener, + GNOME_Evolution_ShellComponentListener_UNSUPPORTED_TYPE, + &ev); + CORBA_exception_free (&ev); + return; + } + /* remove the .ics file */ - path = g_concat_dir_and_file (physical_uri + 7, "calendar.ics"); + path = g_concat_dir_and_file (physical_uri + 7, file_name); rv = unlink (path); g_free (path); if (rv == 0) { @@ -169,6 +194,7 @@ static void xfer_folder (EvolutionShellComponent *shell_component, const char *source_physical_uri, const char *destination_physical_uri, + const char *type, gboolean remove_source, const GNOME_Evolution_ShellComponentListener listener, void *closure) @@ -182,6 +208,7 @@ xfer_folder (EvolutionShellComponent *shell_component, GnomeVFSURI *uri; GnomeVFSFileSize out; char *buf; + const char *file_name; CORBA_exception_init (&ev); @@ -196,6 +223,15 @@ xfer_folder (EvolutionShellComponent *shell_component, return; } + file_name = get_local_file_name_for_folder_type (type); + if (file_name == NULL) { + GNOME_Evolution_ShellComponentListener_notifyResult (listener, + GNOME_Evolution_ShellComponentListener_UNSUPPORTED_TYPE, + &ev); + CORBA_exception_free (&ev); + return; + } + /* open source and destination files */ source_path = g_concat_dir_and_file (source_physical_uri + 7, "calendar.ics"); diff --git a/calendar/gui/component-factory.c b/calendar/gui/component-factory.c index dd161a46dc..4b47fe697d 100644 --- a/calendar/gui/component-factory.c +++ b/calendar/gui/component-factory.c @@ -53,6 +53,20 @@ static const EvolutionShellComponentFolderType folder_types[] = { }; +/* Utility functions. */ + +static const char * +get_local_file_name_for_folder_type (const char *type) +{ + if (strcmp (type, "calendar") == 0) + return "calendar.ics"; + else if (strcmp (type, "tasks") == 0) + return "tasks.ics"; + else + return NULL; +} + + /* EvolutionShellComponent methods and signals. */ static EvolutionShellComponentResult @@ -107,10 +121,12 @@ create_folder (EvolutionShellComponent *shell_component, static void remove_folder (EvolutionShellComponent *shell_component, const char *physical_uri, + const char *type, const GNOME_Evolution_ShellComponentListener listener, void *closure) { CORBA_Environment ev; + const char *file_name; gchar *path; int rv; @@ -128,8 +144,17 @@ remove_folder (EvolutionShellComponent *shell_component, /* FIXME: check if there are subfolders? */ + file_name = get_local_file_name_for_folder_type (type); + if (file_name == NULL) { + GNOME_Evolution_ShellComponentListener_notifyResult (listener, + GNOME_Evolution_ShellComponentListener_UNSUPPORTED_TYPE, + &ev); + CORBA_exception_free (&ev); + return; + } + /* remove the .ics file */ - path = g_concat_dir_and_file (physical_uri + 7, "calendar.ics"); + path = g_concat_dir_and_file (physical_uri + 7, file_name); rv = unlink (path); g_free (path); if (rv == 0) { @@ -169,6 +194,7 @@ static void xfer_folder (EvolutionShellComponent *shell_component, const char *source_physical_uri, const char *destination_physical_uri, + const char *type, gboolean remove_source, const GNOME_Evolution_ShellComponentListener listener, void *closure) @@ -182,6 +208,7 @@ xfer_folder (EvolutionShellComponent *shell_component, GnomeVFSURI *uri; GnomeVFSFileSize out; char *buf; + const char *file_name; CORBA_exception_init (&ev); @@ -196,6 +223,15 @@ xfer_folder (EvolutionShellComponent *shell_component, return; } + file_name = get_local_file_name_for_folder_type (type); + if (file_name == NULL) { + GNOME_Evolution_ShellComponentListener_notifyResult (listener, + GNOME_Evolution_ShellComponentListener_UNSUPPORTED_TYPE, + &ev); + CORBA_exception_free (&ev); + return; + } + /* open source and destination files */ source_path = g_concat_dir_and_file (source_physical_uri + 7, "calendar.ics"); |