2000-05-08 Federico Mena Quintero <federico@helixcode.com> * pcs/cal-backend.h (CalBackendClass): CalBackendClass now is just an interface for calendar backends; this is an abstract class. Put in the vtable for the backend methods. * pcs/cal-backend.c (cal_backend_new): Removed function, since CalBackend is not just an abstract class. Removed implementation-specific functions and made public functions call the virtual methods instead. * pcs/cal-backend-imc.[ch]: New files with the CalBackendIMC implementation; this implements a backend for iCalendar and vCalendar files. Moved the implementation-specific stuff from cal-backend.[ch] to here. * pcs/cal-backend-imc.c (CalendarFormat): Moved enumeration to here. Added a CAL_UNKNOWN value for when the backend is not loaded yet. (cal_backend_imc_init): Initialize priv->format as CAL_UNKNOWN. (save_to_vcal): Use the same VCProdIdProp value as in cal-util/calobj.c. Use "1.0" as the VCVersionProp as per the vCalendar spec. (ensure_uid): Return nothing, since the result value need not be used anymore. (add_object): Since we mark the calendar as dirty anyways, we do not need to check the result value of ensure_uid() anymore. (remove_object): Asssert that we know how to handle the object's type. We do this in add_object() anyways. * pcs/Makefile.am (libpcs_a_SOURCES): Added cal-backend-imc.[ch]. * gui/gnome-cal.c: Replaced debugging printf()s with g_message() so that we can see the line number where they occur. * gui/gnome-cal.c (gnome_calendar_load_cb): Sort of handle the LOAD_METHOD_NOT_SUPPORTED result code, and added a default for the switch. * cal-client/cal-listener.h (CalListenerLoadStatus): Removed enumeration; it is stupid to translate all values for the CalClient when it is going to translate them again. (CalListenerClass::cal_loaded): This signal now passes the LoadStatus directly from the CORBA side. * cal-client/cal-listener.c (Listener_cal_loaded): Do not translate the status value. * cal-client/cal-client.h (CalClientLoadStatus): Added the CAL_CLIENT_LOAD_METHOD_NOT_SUPPORTED error code. * cal-client/cal-client.c (cal_loaded_cb): Translate the CORBA version of the LoadStatus result code. * pcs/cal-factory.c (CalFactoryPrivate): New methods field for the hash table from method strings to the GtkTypes for backend class types. (cal_factory_init): Create the priv->methods hash table. (cal_factory_destroy): Free the priv->methods hash table. (cal_factory_register_method): New function to register a backend class for a particular URI method. (launch_backend_for_uri): New function to launch a backend for a particular URI's method. (load_backend): Use launch_backend_for_uri(). Move the error notification code from load_fn() to here. (create_backend): Use launch_backend_for_uri(). Move the error notification code form create_fn() to here; it is #ifdefed out since currently cal_backend_create() does not have any error reporting capabilities. * idl/evolution-calendar.idl (Listener::LoadStatus): Added a PROTOCOL_NOT_SUPPORTED error code. * pcs/cal-factory.c (cal_factory_load cal_factory_create): Removed functions, since they were supposed to be internal only. (CalFactory_load): Call queue_load_create_job() directly. (CalFactory_create): Likewise. svn path=/trunk/; revision=2921
284 lines
5.7 KiB
C
284 lines
5.7 KiB
C
/* Wombat personal information server - main file
|
||
*
|
||
* Author: Nat Friedman <nat@helixcode.com>
|
||
*
|
||
* Copyright 2000, Helix Code, Inc.
|
||
*/
|
||
|
||
#include <config.h>
|
||
#include <bonobo.h>
|
||
#include <pas/pas-book-factory.h>
|
||
#include <pas/pas-backend-file.h>
|
||
#include <libgnomevfs/gnome-vfs-init.h>
|
||
|
||
#ifdef HAVE_LDAP
|
||
#include <pas/pas-backend-ldap.h>
|
||
#endif
|
||
|
||
#include "calendar/pcs/cal-factory.h"
|
||
#include "calendar/pcs/cal-backend-imc.h"
|
||
|
||
/* The and addressbook calendar factories */
|
||
|
||
static CalFactory *cal_factory;
|
||
static PASBookFactory *pas_book_factory;
|
||
|
||
/* Timeout interval in milliseconds for termination */
|
||
#define EXIT_TIMEOUT 5000
|
||
|
||
/* Timeout ID for termination handler */
|
||
static guint termination_handler_id;
|
||
|
||
|
||
|
||
/* Termination */
|
||
|
||
/* Termination handler. Checks if both factories have zero running backends,
|
||
* and if so terminates the program.
|
||
*/
|
||
static gboolean
|
||
termination_handler (gpointer data)
|
||
{
|
||
if (cal_factory_get_n_backends (cal_factory) == 0
|
||
&& pas_book_factory_get_n_backends (pas_book_factory) == 0)
|
||
gtk_main_quit ();
|
||
|
||
termination_handler_id = 0;
|
||
return FALSE;
|
||
}
|
||
|
||
/* Queues a timeout for handling termination of Wombat */
|
||
static void
|
||
queue_termination (void)
|
||
{
|
||
if (termination_handler_id)
|
||
return;
|
||
|
||
termination_handler_id = g_timeout_add (EXIT_TIMEOUT, termination_handler, NULL);
|
||
}
|
||
|
||
|
||
|
||
static void
|
||
last_book_gone_cb (PASBookFactory *factory, gpointer data)
|
||
{
|
||
queue_termination ();
|
||
}
|
||
|
||
static void
|
||
setup_pas (int argc, char **argv)
|
||
{
|
||
pas_book_factory = pas_book_factory_new ();
|
||
|
||
pas_book_factory_register_backend (
|
||
pas_book_factory, "file", pas_backend_file_new);
|
||
|
||
#ifdef HAVE_LDAP
|
||
pas_book_factory_register_backend (
|
||
pas_book_factory, "ldap", pas_backend_ldap_new);
|
||
#endif
|
||
|
||
gtk_signal_connect (GTK_OBJECT (pas_book_factory),
|
||
"last_book_gone",
|
||
GTK_SIGNAL_FUNC (last_book_gone_cb),
|
||
NULL);
|
||
|
||
pas_book_factory_activate (pas_book_factory);
|
||
}
|
||
|
||
|
||
|
||
/* Personal calendar server */
|
||
|
||
/* Callback used when the calendar factory has no more running backends */
|
||
static void
|
||
last_calendar_gone_cb (CalFactory *factory, gpointer data)
|
||
{
|
||
queue_termination ();
|
||
}
|
||
|
||
#ifdef USING_OAF
|
||
|
||
/* (For the OAF popt stuff, which otherwise does not get in.) */
|
||
#include <gnome.h>
|
||
|
||
#include <liboaf/liboaf.h>
|
||
|
||
static gboolean
|
||
register_pcs (CORBA_Object obj)
|
||
{
|
||
OAF_RegistrationResult result;
|
||
|
||
result = oaf_active_server_register
|
||
("OAFIID:evolution:calendar-factory:1c915858-ece3-4a6f-9d81-ea0f108a9554",
|
||
obj);
|
||
|
||
switch (result) {
|
||
case OAF_REG_SUCCESS:
|
||
return TRUE; /* Wooho! */
|
||
case OAF_REG_NOT_LISTED:
|
||
g_message ("Cannot register the PCS because not listed");
|
||
return FALSE;
|
||
case OAF_REG_ALREADY_ACTIVE:
|
||
g_message ("Cannot register the PCS because already active");
|
||
return FALSE;
|
||
case OAF_REG_ERROR:
|
||
default:
|
||
g_message ("Cannot register the PCS because we suck");
|
||
return FALSE;
|
||
}
|
||
}
|
||
|
||
#else /* USING_OAF */
|
||
|
||
#include <libgnorba/gnorba.h>
|
||
|
||
static gboolean
|
||
register_pcs (CORBA_Object object)
|
||
{
|
||
CORBA_Environment ev;
|
||
int result;
|
||
|
||
CORBA_exception_init (&ev);
|
||
|
||
result = goad_server_register (CORBA_OBJECT_NIL,
|
||
object,
|
||
"evolution:calendar-factory",
|
||
"object",
|
||
&ev);
|
||
|
||
/* FIXME: should Wombat die if it gets errors here? */
|
||
|
||
if (ev._major != CORBA_NO_EXCEPTION || result == -1) {
|
||
g_message ("setup_pcs(): could not register the calendar factory");
|
||
CORBA_exception_free (&ev);
|
||
return FALSE;
|
||
}
|
||
|
||
if (result == -2) {
|
||
g_message ("setup_pcs(): a calendar factory is already registered");
|
||
CORBA_exception_free (&ev);
|
||
return FALSE;
|
||
}
|
||
|
||
CORBA_exception_free (&ev);
|
||
return TRUE;
|
||
}
|
||
|
||
#endif /* USING_OAF */
|
||
|
||
/* Creates the calendar factory object and registers it with GOAD */
|
||
static void
|
||
setup_pcs (int argc, char **argv)
|
||
{
|
||
CORBA_Object object;
|
||
|
||
cal_factory = cal_factory_new ();
|
||
|
||
if (!cal_factory) {
|
||
g_message ("setup_pcs(): Could not create the calendar factory");
|
||
return;
|
||
}
|
||
|
||
cal_factory_register_method (cal_factory, "file", CAL_BACKEND_IMC_TYPE);
|
||
|
||
object = bonobo_object_corba_objref (BONOBO_OBJECT (cal_factory));
|
||
|
||
if (! register_pcs (object)) {
|
||
bonobo_object_unref (BONOBO_OBJECT (cal_factory));
|
||
cal_factory = NULL;
|
||
return;
|
||
}
|
||
|
||
gtk_signal_connect (GTK_OBJECT (cal_factory),
|
||
"last_calendar_gone",
|
||
GTK_SIGNAL_FUNC (last_calendar_gone_cb),
|
||
NULL);
|
||
}
|
||
|
||
|
||
|
||
static void
|
||
setup_config (int argc, char **argv)
|
||
{
|
||
}
|
||
|
||
static void
|
||
setup_vfs (int argc, char **argv)
|
||
{
|
||
if (!gnome_vfs_init ()) {
|
||
g_message ("setup_vfs(): could not initialize GNOME-VFS");
|
||
exit (EXIT_FAILURE);
|
||
}
|
||
}
|
||
|
||
|
||
|
||
#ifdef USING_OAF
|
||
|
||
static void
|
||
init_corba (int *argc, char **argv)
|
||
{
|
||
gnome_init_with_popt_table ("Personal Addressbook Server", "0.0",
|
||
*argc, argv, oaf_popt_options, 0, NULL);
|
||
oaf_init (*argc, argv);
|
||
}
|
||
|
||
#else
|
||
|
||
static void
|
||
init_corba (int *argc, char **argv)
|
||
{
|
||
CORBA_Environment ev;
|
||
|
||
CORBA_exception_init (&ev);
|
||
|
||
gnome_CORBA_init_with_popt_table (
|
||
"Personal Addressbook Server", "0.0",
|
||
argc, argv, NULL, 0, NULL, GNORBA_INIT_SERVER_FUNC, &ev);
|
||
|
||
if (ev._major != CORBA_NO_EXCEPTION) {
|
||
g_message ("init_bonobo(): could not initialize GOAD");
|
||
CORBA_exception_free (&ev);
|
||
exit (EXIT_FAILURE);
|
||
}
|
||
|
||
CORBA_exception_free (&ev);
|
||
}
|
||
|
||
#endif
|
||
|
||
static void
|
||
init_bonobo (int *argc, char **argv)
|
||
{
|
||
init_corba (argc, argv);
|
||
|
||
if (!bonobo_init (CORBA_OBJECT_NIL, CORBA_OBJECT_NIL, CORBA_OBJECT_NIL)) {
|
||
g_message ("init_bonobo(): could not initialize Bonobo");
|
||
exit (EXIT_FAILURE);
|
||
}
|
||
}
|
||
|
||
int
|
||
main (int argc, char **argv)
|
||
{
|
||
init_bonobo (&argc, argv);
|
||
setup_vfs (argc, argv);
|
||
|
||
setup_pas (argc, argv);
|
||
setup_pcs (argc, argv);
|
||
setup_config (argc, argv);
|
||
|
||
/*g_log_set_always_fatal ((GLogLevelFlags) 0xFFFF);*/
|
||
|
||
bonobo_main ();
|
||
|
||
bonobo_object_unref (BONOBO_OBJECT (cal_factory));
|
||
cal_factory = NULL;
|
||
|
||
bonobo_object_unref (BONOBO_OBJECT (pas_book_factory));
|
||
pas_book_factory = NULL;
|
||
|
||
return 0;
|
||
}
|