* Select the first inbox of the newly selected account
[modest] / src / modest-singletons.h
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 #ifndef __MODEST_SINGLETONS_H__
31 #define __MODEST_SINGLETONS_H__
32
33 #include <config.h>
34
35 #include <glib-object.h>
36 #include <modest-conf.h>
37 #include <modest-email-clipboard.h>
38 #include <modest-account-mgr.h>
39 #include <modest-mail-operation-queue.h>
40 #include <modest-cache-mgr.h>
41 #include <modest-tny-platform-factory.h>
42 #include "widgets/modest-window-mgr.h"
43
44 G_BEGIN_DECLS
45
46 /* convenience macros */
47 #define MODEST_TYPE_SINGLETONS             (modest_singletons_get_type())
48 #define MODEST_SINGLETONS(obj)             (G_TYPE_CHECK_INSTANCE_CAST((obj),MODEST_TYPE_SINGLETONS,ModestSingletons))
49 #define MODEST_SINGLETONS_CLASS(klass)     (G_TYPE_CHECK_CLASS_CAST((klass),MODEST_TYPE_SINGLETONS,GObject))
50 #define MODEST_IS_SINGLETONS(obj)          (G_TYPE_CHECK_INSTANCE_TYPE((obj),MODEST_TYPE_SINGLETONS))
51 #define MODEST_IS_SINGLETONS_CLASS(klass)  (G_TYPE_CHECK_CLASS_TYPE((klass),MODEST_TYPE_SINGLETONS))
52 #define MODEST_SINGLETONS_GET_CLASS(obj)   (G_TYPE_INSTANCE_GET_CLASS((obj),MODEST_TYPE_SINGLETONS,ModestSingletonsClass))
53
54 typedef struct _ModestSingletons      ModestSingletons;
55 typedef struct _ModestSingletonsClass ModestSingletonsClass;
56
57 struct _ModestSingletons {
58          GObject parent;
59 };
60
61 struct _ModestSingletonsClass {
62         GObjectClass parent_class;
63 };
64
65
66 /**
67  * modest_singletons_get_type:
68  * 
69  * get the GType for ModestSingletons
70  *  
71  * Returns: the GType
72  */
73 GType        modest_singletons_get_type    (void) G_GNUC_CONST;
74
75
76 /**
77  * modest_singletons_new:
78  * 
79  * create a new ModestSingletons instance;
80  * don't use this function directly, use the modest-runtime
81  * functions instead.
82  * 
83  * Returns: a new ModestSingletons instance, or NULL in case
84  * of any error
85  */
86 ModestSingletons*    modest_singletons_new         (void);
87
88
89 /**
90  * modest_singletons_get_conf:
91  * @self: a valid ModestSingletons instance
92  * 
93  * get the ModestConf singleton instance
94  * don't use this function directly, use the modest-runtime
95  * functions instead.
96  *
97  * Returns: the ModestConf singleton
98  **/
99 ModestConf*               modest_singletons_get_conf          (ModestSingletons *self);
100
101
102 /**
103  * modest_singletons_get_account_mgr:
104  * @self: a valid ModestSingletons instance
105  * 
106  * get the ModestAccountMgr singleton instance
107  * don't use this function directly, use the modest-runtime
108  * functions instead.
109  * 
110  * Returns: the ModestAccountMgr singleton
111  **/
112 ModestAccountMgr*         modest_singletons_get_account_mgr   (ModestSingletons *self);
113
114 /**
115  * modest_singletons_get_account_mgr:
116  * @self: a valid #ModestSingletons instance
117  * 
118  * get the #ModestEamilClipboard singleton instance
119  * don't use this function directly, use the modest-runtime
120  * functions instead.
121  * 
122  * Returns: the #ModestEmailClipboard singleton
123  **/
124 ModestEmailClipboard*      modest_singletons_get_email_clipboard (ModestSingletons *self);
125
126
127 /**
128  * modest_singletons_get_cache_mgr:
129  * @self: a valid #ModestSingletons instance
130  * 
131  * get the #ModestCacheMgr singleton instance
132  * don't use this function directly, use the modest-runtime
133  * functions instead.
134  *
135  * Returns: the #ModestCacheMgr singleton
136  **/
137 ModestCacheMgr*           modest_singletons_get_cache_mgr     (ModestSingletons *self);
138
139
140
141 /**
142  * modest_singletons_get_platform_factory:
143  * @self: a valid #ModestSingletons instance
144  * 
145  * get the #TnyPlatformFactory singleton instance
146  * don't use this function directly, use the modest-runtime
147  * functions instead.
148  *
149  * Returns: the #TnyPlatformFactory singleton
150  **/
151 TnyPlatformFactory*       modest_singletons_get_platform_factory  (ModestSingletons *self);
152
153
154 /**
155  * modest_singletons_get_device:
156  * @self: a valid #ModestSingletons instance
157  * 
158  * get the #TnyDevice singleton instance
159  * don't use this function directly, use the modest-runtime
160  * functions instead.
161  *
162  * Returns: the #TnyDevice singleton
163  **/
164 TnyDevice*                 modest_singletons_get_device       (ModestSingletons *self);
165
166
167 /**
168  * modest_singletons_get_mail_operation_queue:
169  * @self: a valid ModestSingletons instance
170  * 
171  * get the ModestMailOperationQueue singleton instance
172  * don't use this function directly, use the modest-runtime
173  * functions instead.
174  *
175  * Returns: the ModestMailOperationQueue singleton
176  **/
177 ModestMailOperationQueue* modest_singletons_get_mail_operation_queue (ModestSingletons *self);
178
179 /**
180  * modest_singletons_get_window_mgr:
181  * @self: 
182  * 
183  * Gets the #ModestWindowMgr singleton instance. Don't use this
184  * function directly, use the modest-runtime function instead.
185  *
186  * Return value: the singleton instance of #ModestWindowMgr
187  **/
188 ModestWindowMgr*          modest_singletons_get_window_mgr           (ModestSingletons *self);
189
190 G_END_DECLS
191
192 #endif /* __MODEST_SINGLETONS_H__ */
193