diff options
Diffstat (limited to 'calendar/cal-client')
-rw-r--r-- | calendar/cal-client/cal-client.c | 126 | ||||
-rw-r--r-- | calendar/cal-client/cal-client.h | 8 |
2 files changed, 110 insertions, 24 deletions
diff --git a/calendar/cal-client/cal-client.c b/calendar/cal-client/cal-client.c index d6d92b6239..ddf3617072 100644 --- a/calendar/cal-client/cal-client.c +++ b/calendar/cal-client/cal-client.c @@ -143,6 +143,67 @@ cal_client_get_type (void) return cal_client_type; } +GType +cal_client_open_status_enum_get_type (void) +{ + static GType cal_client_open_status_enum_type = 0; + + if (!cal_client_open_status_enum_type) { + static GEnumValue values [] = { + { CAL_CLIENT_OPEN_SUCCESS, "CalClientOpenSuccess", "success" }, + { CAL_CLIENT_OPEN_ERROR, "CalClientOpenError", "error" }, + { CAL_CLIENT_OPEN_NOT_FOUND, "CalClientOpenNotFound", "not-found" }, + { CAL_CLIENT_OPEN_PERMISSION_DENIED, "CalClientOpenPermissionDenied", "denied" }, + { CAL_CLIENT_OPEN_METHOD_NOT_SUPPORTED, "CalClientOpenMethodNotSupported", "unsupported" }, + { -1, NULL, NULL } + }; + + cal_client_open_status_enum_type = g_enum_register_static ("CalClientOpenStatusEnum", values); + } + + return cal_client_open_status_enum_type; +} + +GType +cal_client_set_mode_status_enum_get_type (void) +{ + static GType cal_client_set_mode_status_enum_type = 0; + + if (!cal_client_set_mode_status_enum_type) { + static GEnumValue values [] = { + { CAL_CLIENT_SET_MODE_SUCCESS, "CalClientSetModeSuccess", "success" }, + { CAL_CLIENT_SET_MODE_ERROR, "CalClientSetModeError", "error" }, + { CAL_CLIENT_SET_MODE_NOT_SUPPORTED, "CalClientSetModeNotSupported", "unsupported" }, + { -1, NULL, NULL } + }; + + cal_client_set_mode_status_enum_type = + g_enum_register_static ("CalClientSetModeStatusEnum", values); + } + + return cal_client_set_mode_status_enum_type; +} + +GType +cal_mode_enum_get_type (void) +{ + static GType cal_mode_enum_type = 0; + + if (!cal_mode_enum_type) { + static GEnumValue values [] = { + { CAL_MODE_INVALID, "CalModeInvalid", "invalid" }, + { CAL_MODE_LOCAL, "CalModeLocal", "local" }, + { CAL_MODE_REMOTE, "CalModeRemote", "remote" }, + { CAL_MODE_ANY, "CalModeAny", "any" }, + { -1, NULL, NULL } + }; + + cal_mode_enum_type = g_enum_register_static ("CalModeEnum", values); + } + + return cal_mode_enum_type; +} + /* Class initialization function for the calendar client */ static void cal_client_class_init (CalClientClass *klass) @@ -161,7 +222,7 @@ cal_client_class_init (CalClientClass *klass) NULL, NULL, g_cclosure_marshal_VOID__ENUM, G_TYPE_NONE, 1, - G_TYPE_ENUM); + CAL_CLIENT_OPEN_STATUS_ENUM_TYPE); cal_client_signals[CAL_SET_MODE] = g_signal_new ("cal_set_mode", G_TYPE_FROM_CLASS (klass), @@ -170,8 +231,8 @@ cal_client_class_init (CalClientClass *klass) NULL, NULL, cal_util_marshal_VOID__ENUM_ENUM, G_TYPE_NONE, 2, - G_TYPE_ENUM, - G_TYPE_ENUM); + CAL_CLIENT_SET_MODE_STATUS_ENUM_TYPE, + CAL_MODE_ENUM_TYPE); cal_client_signals[OBJ_UPDATED] = g_signal_new ("obj_updated", G_TYPE_FROM_CLASS (klass), @@ -372,7 +433,7 @@ cal_client_finalize (GObject *object) } priv->w_client = NULL; - destroy_factories (client); + /* destroy_factories (client); */ destroy_cal (client); priv->load_state = CAL_CLIENT_LOAD_NOT_LOADED; @@ -645,29 +706,17 @@ client_forget_password_cb (WombatClient *w_client, -/** - * cal_client_construct: - * @client: A calendar client. - * - * Constructs a calendar client object by contacting all available - * calendar factories. - * - * Return value: The same object as the @client argument, or NULL if the - * calendar factory could not be contacted. - **/ -CalClient * -cal_client_construct (CalClient *client) +static GList * +get_factories (void) { - CalClientPrivate *priv; + static GList *factories = NULL; GNOME_Evolution_Calendar_CalFactory factory; Bonobo_ServerInfoList *servers; CORBA_Environment ev; int i; - g_return_val_if_fail (client != NULL, NULL); - g_return_val_if_fail (IS_CAL_CLIENT (client), NULL); - - priv = client->priv; + if (factories != NULL) + return factories; CORBA_exception_init (&ev); @@ -689,18 +738,47 @@ cal_client_construct (CalClient *client) factory = (GNOME_Evolution_Calendar_CalFactory) bonobo_activation_activate_from_id (info->iid, 0, NULL, &ev); if (BONOBO_EX (&ev)) { +#if 0 g_warning ("cal_client_construct: Could not activate calendar server %s", info->iid); CORBA_free (servers); CORBA_exception_free (&ev); return NULL; +#endif } - - priv->factories = g_list_prepend (priv->factories, factory); + else + factories = g_list_prepend (factories, factory); } CORBA_free (servers); - CORBA_exception_free (&ev); + return factories; +} + +/** + * cal_client_construct: + * @client: A calendar client. + * + * Constructs a calendar client object by contacting all available + * calendar factories. + * + * Return value: The same object as the @client argument, or NULL if the + * calendar factory could not be contacted. + **/ +CalClient * +cal_client_construct (CalClient *client) +{ + CalClientPrivate *priv; + GNOME_Evolution_Calendar_CalFactory factory; + Bonobo_ServerInfoList *servers; + CORBA_Environment ev; + int i; + + g_return_val_if_fail (client != NULL, NULL); + g_return_val_if_fail (IS_CAL_CLIENT (client), NULL); + + priv = client->priv; + priv->factories = get_factories (); + return client; } diff --git a/calendar/cal-client/cal-client.h b/calendar/cal-client/cal-client.h index 3d6a4fe85d..3ea0b1a213 100644 --- a/calendar/cal-client/cal-client.h +++ b/calendar/cal-client/cal-client.h @@ -36,6 +36,10 @@ G_BEGIN_DECLS #define IS_CAL_CLIENT(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), CAL_CLIENT_TYPE)) #define IS_CAL_CLIENT_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), CAL_CLIENT_TYPE)) +#define CAL_CLIENT_OPEN_STATUS_ENUM_TYPE (cal_client_open_status_enum_get_type ()) +#define CAL_CLIENT_SET_MODE_STATUS_ENUM_TYPE (cal_client_set_mode_status_enum_get_type ()) +#define CAL_MODE_ENUM_TYPE (cal_mode_enum_get_type ()) + typedef struct _CalClient CalClient; typedef struct _CalClientClass CalClientClass; @@ -122,6 +126,10 @@ typedef gchar * (* CalClientAuthFunc) (CalClient *client, GType cal_client_get_type (void); +GType cal_client_open_status_enum_get_type (void); +GType cal_client_set_mode_status_enum_get_type (void); +GType cal_mode_enum_get_type (void); + CalClient *cal_client_construct (CalClient *client); CalClient *cal_client_new (void); |