2007-10-08 [colin] 3.0.2cvs38
[claws.git] / src / addritem.h
1 /*
2  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
3  * Copyright (C) 2001-2007 Match Grun and the Claws Mail team
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 3 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program. If not, see <http://www.gnu.org/licenses/>.
17  * 
18  */
19
20 /*
21  * Address item data.
22  */
23
24 #ifndef __ADDRITEM_H__
25 #define __ADDRITEM_H__
26
27 #include <stdio.h>
28 #include <glib.h>
29
30 #define ADDRITEM_OBJECT(obj)    ((AddrItemObject *)obj)
31 #define ADDRITEM_TYPE(obj)      (ADDRITEM_OBJECT(obj)->type)
32 #define ADDRITEM_NAME(obj)      (ADDRITEM_OBJECT(obj)->name)
33 #define ADDRITEM_ID(obj)        (ADDRITEM_OBJECT(obj)->uid)
34 #define ADDRITEM_PARENT(obj)    (ADDRITEM_OBJECT(obj)->parent)
35 #define ADDRITEM_SUBTYPE(obj)   (ADDRITEM_OBJECT(obj)->subType)
36
37 typedef enum {
38         ITEMTYPE_NONE,
39         ITEMTYPE_PERSON,
40         ITEMTYPE_EMAIL,
41         ITEMTYPE_FOLDER,
42         ITEMTYPE_GROUP,
43         ITEMTYPE_INDEX,
44         ITEMTYPE_INTERFACE,
45         ITEMTYPE_DATASOURCE
46 } ItemObjectType;
47
48 typedef enum {
49         ADDRFOLDER_NONE,
50         ADDRFOLDER_ROOT,
51         ADDRFOLDER_REGULAR,
52         ADDRFOLDER_CATEGORY,
53         ADDRFOLDER_QUERY_RESULTS
54 } AddressFolderType;
55
56 typedef enum {
57         NONE,
58         ADD_ENTRY,
59         UPDATE_ENTRY,
60         DELETE_ENTRY
61 } ContactStatus;
62
63 typedef struct _AddrItemObject AddrItemObject;
64 struct _AddrItemObject {
65         ItemObjectType type;
66         gchar          *name;
67         gchar          *uid;
68         AddrItemObject *parent;
69         gint           subType;
70 };
71
72 typedef struct _ItemPerson ItemPerson;
73 struct _ItemPerson {
74         AddrItemObject obj;
75         gchar    *firstName;
76         gchar    *lastName;
77         gchar    *nickName;
78         gchar    *externalID;
79         GList    *listEMail;
80         GList    *listAttrib;
81         gboolean isOpened;
82         ContactStatus status;
83 };
84
85 typedef struct _ItemEMail ItemEMail;
86 struct _ItemEMail {
87         AddrItemObject obj;
88         gchar *address;
89         gchar *remarks;
90 };
91
92 typedef struct _UserAttribute UserAttribute;
93 struct _UserAttribute {
94         gchar *uid;
95         gchar *name;
96         gchar *value;
97 };
98
99 typedef struct _ItemFolder ItemFolder;
100 struct _ItemFolder {
101         AddrItemObject obj;
102         gchar    *remarks;
103         gboolean isRoot;        /* TRUE if root folder */
104         GList    *listItems;    /* Used for temporary items only */
105         GList    *listFolder;   /* List of contained (child) folders */
106         GList    *listPerson;   /* List of contained persons */
107         GList    *listGroup;    /* List of contained (child) groups */
108         AddressFolderType folderType;   /* Folder type */
109         gpointer *folderData;           /* Pointer to folder's data */
110         gboolean isHidden;      /* TRUE if folder is hidden */
111 };
112
113 typedef struct _ItemGroup ItemGroup;
114 struct _ItemGroup {
115         AddrItemObject obj;
116         gchar *remarks;
117         GList *listEMail;
118 };
119
120 /* Function prototypes */
121 ItemEMail *addritem_create_item_email   ( void );
122 ItemEMail *addritem_copy_item_email     ( ItemEMail *item );
123 ItemEMail *addritem_copyfull_item_email ( ItemEMail *item );
124 void addritem_email_set_alias           ( ItemEMail *email, const gchar *value );
125 void addritem_email_set_address         ( ItemEMail *email, const gchar *value );
126 void addritem_email_set_remarks         ( ItemEMail *email, const gchar *value );
127 void addritem_free_item_email           ( ItemEMail *item );
128
129 UserAttribute *addritem_create_attribute( void );
130 UserAttribute *addritem_copy_attribute  ( UserAttribute *item );
131 void addritem_attrib_set_id             ( UserAttribute *item, const gchar *value );
132 void addritem_attrib_set_name           ( UserAttribute *item, const gchar *value );
133 void addritem_attrib_set_value          ( UserAttribute *item, const gchar *value );
134 void addritem_free_attribute            ( UserAttribute *item );
135
136 ItemPerson *addritem_create_item_person ( void );
137 ItemPerson *addritem_copy_item_person   ( ItemPerson *item );
138 void addritem_person_set_first_name     ( ItemPerson *person, const gchar *value );
139 void addritem_person_set_last_name      ( ItemPerson *person, const gchar *value );
140 void addritem_person_set_nick_name      ( ItemPerson *person, const gchar *value );
141 void addritem_person_set_common_name    ( ItemPerson *person, const gchar *value );
142 void addritem_person_set_external_id    ( ItemPerson *person, const gchar *value );
143 void addritem_person_set_opened         ( ItemPerson *person, const gboolean value );
144 void addritem_free_item_person          ( ItemPerson *person );
145 void addritem_free_list_email           ( GList *list );
146 void addritem_free_list_attribute       ( GList *list );
147
148 ItemGroup *addritem_create_item_group   ( void );
149 ItemGroup *addritem_copy_item_group     ( ItemGroup *item );
150 void addritem_free_item_group           ( ItemGroup *group );
151 void addritem_group_set_name            ( ItemGroup *group, const gchar *value );
152
153 void addritem_print_item_email          ( ItemEMail *item, FILE *stream );
154 void addritem_print_item_person         ( ItemPerson *person, FILE *stream );
155 void addritem_print_item_group          ( ItemGroup *group, FILE *stream );
156 void addritem_print_item_folder         ( ItemFolder *folder, FILE *stream );
157
158 gboolean addritem_person_add_email              ( ItemPerson *person, ItemEMail *email );
159 ItemEMail *addritem_person_remove_email         ( ItemPerson *person, ItemEMail *email );
160
161 void addritem_person_add_attribute              ( ItemPerson *person, UserAttribute *attrib );
162 void addritem_person_remove_attribute   ( ItemPerson *person, const gchar *attrib );
163 gboolean addritem_person_has_attribute  ( ItemPerson *person, const gchar *attrib );
164
165 ItemFolder *addritem_create_item_folder ( void );
166 ItemFolder *addritem_copy_item_folder   ( ItemFolder *item );
167 void addritem_folder_set_name           ( ItemFolder *folder, const gchar *value );
168 void addritem_folder_set_remarks        ( ItemFolder *folder, const gchar *value );
169 void addritem_folder_set_hidden         ( ItemFolder *folder, const gboolean value );
170 void addritem_free_item_folder          ( ItemFolder *folder );
171
172 gboolean addritem_group_add_email       ( ItemGroup *group, ItemEMail *email );
173
174 gboolean addritem_folder_add_person     ( ItemFolder *folder, ItemPerson *item );
175 ItemPerson *addritem_folder_remove_person( ItemFolder *group, ItemPerson *person );
176
177 gboolean addritem_folder_add_folder     ( ItemFolder *folder, ItemFolder *item );
178 gboolean addritem_folder_add_group      ( ItemFolder *folder, ItemGroup *item );
179 GList *addritem_folder_get_person_list  ( ItemFolder *folder );
180 GList *addritem_folder_get_group_list   ( ItemFolder *folder );
181
182 void addritem_parse_first_last          ( ItemPerson *person );
183 GList *addritem_folder_path             ( const ItemFolder *folder,
184                                           const gboolean seq );
185 gchar *addritem_format_email            ( ItemEMail *email );
186
187 #endif /* __ADDRITEM_H__ */