aboutsummaryrefslogtreecommitdiffstats
path: root/shell/e-service.h
diff options
context:
space:
mode:
authorbertrand <bertrand@helixcode.com>2000-03-12 13:09:43 +0800
committerBertrand Guiheneuf <bertrand@src.gnome.org>2000-03-12 13:09:43 +0800
commitf669ff481f57cf5b609ea2e8fe30cfb8dece8587 (patch)
treee0b812f92689476aed9751bfda46b3071af159a5 /shell/e-service.h
parent679fa9316ef0cfb3fea44adeb4ab4a7795ae71ed (diff)
downloadgsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar.gz
gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar.zst
gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.zip
add a field refering to a service associated to the efolder. In the case
2000-03-12 bertrand <bertrand@helixcode.com> * shell/e-folder.h: add a field refering to a service associated to the efolder. In the case of distant folders, it is generally a server. * shell/e-service.c: New class. Models a service. A service is an object with an URI and a root folder. It genreally reporesents a distant folder. A service is generally a ressource shared amongst several folders. * shell/e-service.h: 2000-03-10 bertrand <bertrand@helixcode.com> * camel-service.h: cosmetic changes. svn path=/trunk/; revision=2100
Diffstat (limited to 'shell/e-service.h')
-rw-r--r--shell/e-service.h140
1 files changed, 140 insertions, 0 deletions
diff --git a/shell/e-service.h b/shell/e-service.h
new file mode 100644
index 0000000000..54d54d6b38
--- /dev/null
+++ b/shell/e-service.h
@@ -0,0 +1,140 @@
+/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
+/* camel-stream-fs.h : abstract class for the Evolution services */
+
+/*
+ *
+ * Author :
+ * Bertrand Guiheneuf <bertrand@helixcode.com>
+ * Miguel de Icaza (miguel@helixcode.com)
+ *
+ * Copyright 2000 Helix Code, Inc. (http://www.helixcode.com)
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License as
+ * published by the Free Software Foundation; either version 2 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
+ * USA
+ */
+
+
+/*
+ * this class represents a service, that is, an object
+ * we can get e-folders from.
+ *
+ * In the case of the mail, it represents :
+ * - a store to get mail folder from (an imap server,
+ * an mbox toplevel directory
+ * or
+ * - a mail transport thanks to which you can send
+ * mail from.
+ *
+ * This class may probably handle the connection
+ * operations, and probably allow the some kind of
+ * configuration of the authentication methods
+ * used.
+ *
+ *
+ * NOTE : this class shares a lot of code and properties
+ * with the folder class. It may be a good idea to determine
+ * exactely if it would be useful to make both classes
+ * be children of another parent abstract class.
+ * for the moment, we don't really show the service to
+ * the user in the UI, so that there is not an urgent
+ * need to create the abstract parent class.
+ *
+ * - ber.
+ *
+ */
+
+
+#ifndef _E_SERVICE_H_
+#define _E_SERVICE_H_
+
+#include <gtk/gtkobject.h>
+
+#define E_SERVICE_TYPE (e_service_get_type ())
+#define E_SERVICE(o) (GTK_CHECK_CAST ((o), E_SERVICE_TYPE, EService))
+#define E_SERVICE_CLASS(k) (GTK_CHECK_CLASS_CAST((k), E_SERVICE_TYPE, EServiceClass))
+#define E_IS_SERVICE(o) (GTK_CHECK_TYPE ((o), E_SERVICE_TYPE))
+#define E_IS_SERVICE_CLASS(k) (GTK_CHECK_CLASS_TYPE ((k), E_SERVICE_TYPE))
+
+
+typedef enum {
+ E_SERVICE_MAIL = 1 << 0,
+ E_SERVICE_CONTACTS = 1 << 1,
+ E_SERVICE_CALENDAR = 1 << 2,
+ E_SERVICE_TASKS = 1 << 3,
+ E_SERVICE_OTHER = 1 << 4
+} EServiceType;
+
+typedef struct {
+ GtkObject parent_object;
+
+ EFolder *root_efolder; /* a service may have a root EFolder */
+
+ /*
+ * General properties
+ */
+ char *uri; /* Location */
+ char *name; /* Short name */
+ char *desc; /* Full description */
+ char *home_page; /* Home page for this service */
+
+ EServiceType type; /* type of the service */
+
+
+} EService;
+
+typedef struct {
+ GtkObjectClass parent_class;
+
+} EServiceClass;
+
+GtkType e_service_get_type (void);
+void e_service_construct (EService *eservice,
+ EServiceType type,
+ const char *uri,
+ const char *name,
+ const char *desc,
+ const char *home_page);
+EService *e_service_new (EServiceType type,
+ const char *uri,
+ const char *name,
+ const char *desc,
+ const char *home_page);
+
+EFolder *e_service_get_root_efolder (EService *eservice);
+
+void e_service_set_uri (EService *eservice,
+ const char *uri);
+const char *e_service_get_uri (EService *eservice);
+
+void e_service_set_description (EService *eservice,
+ const char *desc);
+const char *e_service_get_description (EService *eservice);
+
+void e_service_set_home_page (EService *eservice,
+ const char *desc);
+const char *e_service_get_home_page (EService *eservice);
+
+const char *e_service_get_name (EService *eservice);
+void e_service_set_name (EService *eservice,
+ const char *name);
+
+
+const char *e_service_get_type_name (EService *eservice);
+
+#endif /* _E_SERVICE_H_ */
+
+
+
+