* all:
[modest] / src / modest-tny-folder.c
1 /* Copyright (c) 2006, Nokia Corporation
2  * All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions are
6  * met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  *   notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  *   notice, this list of conditions and the following disclaimer in the
12  *   documentation and/or other materials provided with the distribution.
13  * * Neither the name of the Nokia Corporation nor the names of its
14  *   contributors may be used to endorse or promote products derived from
15  *   this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
18  * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
19  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
20  * PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER
21  * OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25  * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26  * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27  * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  */
29
30 #include <glib.h>
31 #include <glib/gi18n.h>
32 #include <string.h>
33 #include <modest-tny-folder.h>
34
35
36 typedef struct {
37         ModestLocalFolderType   type;
38         const gchar             *name;
39         const gchar             *display_name;
40 } ModestLocalFolder;
41
42 const ModestLocalFolder ModestLocalFolderMap[] = {
43         { MODEST_LOCAL_FOLDER_TYPE_JUNK,    "junk",    N_("junk")},
44         { MODEST_LOCAL_FOLDER_TYPE_TRASH,   "trash",   N_("trash")},
45         { MODEST_LOCAL_FOLDER_TYPE_DRAFTS,  "drafts",  N_("drafts")},
46         { MODEST_LOCAL_FOLDER_TYPE_SENT,    "sent",    N_("sent")},
47         { MODEST_LOCAL_FOLDER_TYPE_OUTBOX,  "outbox",  N_("outbox")},
48         { MODEST_LOCAL_FOLDER_TYPE_ARCHIVE, "archive", N_("archive")}
49 };
50
51
52 ModestLocalFolderType
53 modest_tny_folder_get_local_folder_type (const gchar *name)
54 {
55         int i;
56
57         g_return_val_if_fail (name, MODEST_LOCAL_FOLDER_TYPE_UNKNOWN);
58
59         for (i = 0; i != G_N_ELEMENTS(ModestLocalFolderMap); ++i) {
60                 if (strcmp (ModestLocalFolderMap[i].name, name) == 0)
61                         return ModestLocalFolderMap[i].type;
62         }
63         return MODEST_LOCAL_FOLDER_TYPE_UNKNOWN;
64 }
65
66 const gchar*
67 modest_tny_folder_get_local_folder_type_name (ModestLocalFolderType type)
68 {
69         int i = 0;
70         g_return_val_if_fail (type > MODEST_LOCAL_FOLDER_TYPE_UNKNOWN &&
71                               type < MODEST_LOCAL_FOLDER_TYPE_NUM, NULL);
72         
73         for (i = 0; i != G_N_ELEMENTS(ModestLocalFolderMap); ++i) {
74                 if (ModestLocalFolderMap[i].type == type)
75                         return ModestLocalFolderMap[i].name;
76         }
77         return NULL;    
78 }
79
80
81 const gchar*
82 modest_tny_folder_get_local_folder_type_display_name (ModestLocalFolderType type)
83 {
84         int i = 0;
85         g_return_val_if_fail (type > MODEST_LOCAL_FOLDER_TYPE_UNKNOWN &&
86                               type < MODEST_LOCAL_FOLDER_TYPE_NUM, NULL);
87         
88         for (i = 0; i != G_N_ELEMENTS(ModestLocalFolderMap); ++i) {
89                 if (ModestLocalFolderMap[i].type == type)
90                         return ModestLocalFolderMap[i].display_name;
91         }
92         return NULL;    
93 }
94
95
96
97
98 TnyFolderType
99 modest_tny_folder_guess_folder_type_from_name (const gchar* name)
100 {
101         gint  type;
102         gchar *folder;
103
104         g_return_val_if_fail (name, TNY_FOLDER_TYPE_UNKNOWN);
105         
106         type = TNY_FOLDER_TYPE_UNKNOWN;
107         folder = g_utf8_strdown (name, strlen(name));
108
109         if (strcmp (folder, "inbox") == 0 ||
110             strcmp (folder, _("inbox")) == 0)
111                 type = TNY_FOLDER_TYPE_INBOX;
112         else if (strcmp (folder, "outbox") == 0 ||
113                  strcmp (folder, _("outbox")) == 0)
114                 type = TNY_FOLDER_TYPE_OUTBOX;
115         else if (g_str_has_prefix(folder, "junk") ||
116                  g_str_has_prefix(folder, _("junk")))
117                 type = TNY_FOLDER_TYPE_JUNK;
118         else if (g_str_has_prefix(folder, "trash") ||
119                  g_str_has_prefix(folder, _("trash")))
120                 type = TNY_FOLDER_TYPE_TRASH;
121         else if (g_str_has_prefix(folder, "sent") ||
122                  g_str_has_prefix(folder, _("sent")))
123                 type = TNY_FOLDER_TYPE_SENT;
124         else if (g_str_has_prefix(folder, "draft") ||
125                  g_str_has_prefix(folder, _("draft")))
126                 type = TNY_FOLDER_TYPE_DRAFTS;
127         else if (g_str_has_prefix(folder, "notes") ||
128                  g_str_has_prefix(folder, _("notes")))
129                 type = TNY_FOLDER_TYPE_NOTES;
130         else if (g_str_has_prefix(folder, "contacts") ||
131                  g_str_has_prefix(folder, _("contacts")))
132                 type = TNY_FOLDER_TYPE_CONTACTS;
133         else if (g_str_has_prefix(folder, "calendar") ||
134                  g_str_has_prefix(folder, _("calendar")))
135                 type = TNY_FOLDER_TYPE_CALENDAR;
136         
137         g_free (folder);
138         return type;
139 }
140
141
142
143 TnyFolderType
144 modest_tny_folder_guess_folder_type (const TnyFolder *folder)
145 {
146         TnyFolderType type;
147
148         g_return_val_if_fail (folder, TNY_FOLDER_TYPE_UNKNOWN);
149
150         type = tny_folder_get_folder_type (TNY_FOLDER (folder));
151         
152         if (type == TNY_FOLDER_TYPE_UNKNOWN) {
153                 const gchar *folder_name;
154
155                 folder_name = tny_folder_get_name (TNY_FOLDER (folder));
156                 type =  modest_tny_folder_guess_folder_type_from_name (folder_name);
157         }
158
159         return type;
160 }
161
162
163 ModestTnyFolderRules
164 modest_tny_folder_get_folder_rules   (const TnyFolder *folder)
165 {
166         g_return_val_if_fail (folder, 0);
167         
168         /* FIXME -- implement this */
169         return 0;
170 }