diff options
author | bertrand <bertrand@helixcode.com> | 2000-03-12 13:09:43 +0800 |
---|---|---|
committer | Bertrand Guiheneuf <bertrand@src.gnome.org> | 2000-03-12 13:09:43 +0800 |
commit | f669ff481f57cf5b609ea2e8fe30cfb8dece8587 (patch) | |
tree | e0b812f92689476aed9751bfda46b3071af159a5 /shell/e-service.h | |
parent | 679fa9316ef0cfb3fea44adeb4ab4a7795ae71ed (diff) | |
download | gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar.gz gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar.bz2 gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar.lz gsoc2013-evolution-f669ff481f57cf5b609ea2e8fe30cfb8dece8587.tar.xz 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.h | 140 |
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_ */ + + + + |