Merge "custom eail widget implementation" into tizen
[platform/core/uifw/eail.git] / eail / eail_app.h
1 /*
2  * Copyright (c) 2013 Samsung Electronics Co., Ltd.
3  *
4  * This library is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU Lesser General Public
6  * License as published by the Free Software Foundation; either
7  * version 2 of the License, or (at your option) any later version.
8  *
9  * This library is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
12  * Lesser General Public License for more details.
13  *
14  * You should have received a copy of the GNU Lesser General Public License
15  * along with this library; see the file COPYING.LIB.  If not, write to
16  * the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
17  * Boston, MA 02110-1301, USA.
18  */
19
20 /**
21  * @file eail_app.h
22  *
23  * @brief Header for EailApp implementation
24  */
25
26 #ifndef EAIL_APP_H
27 #define EAIL_APP_H
28
29 #include <atk/atk.h>
30
31 /**
32  * @brief Returns a value corresponding to the type of EailApp class
33  */
34 #define EAIL_TYPE_APP             (eail_app_get_type())
35
36 /**
37  * @brief Macro upcasts an instance (obj) of a subclass to the EailApp
38  * type
39  *
40  * @param obj AtkObject instance
41  */
42 #define EAIL_APP(obj)             (G_TYPE_CHECK_INSTANCE_CAST((obj), \
43                                    EAIL_TYPE_APP, EailApp))
44
45 /**
46  * @brief Macro upcasts a subclass (klass) to the EailApp class
47  *
48  * @param klass subclass object
49  */
50 #define EAIL_APP_CLASS(klass)     (G_TYPE_CHECK_CLASS_CAST((klass), \
51                                    EAIL_TYPE_APP, EailAppClass))
52
53 /**
54  * @brief Tests whether object (obj) is an instance of EailApp class
55  *
56  * @param obj AtkObject instance
57  */
58 #define EAIL_IS_APP(obj)          (G_TYPE_CHECK_INSTANCE_TYPE((obj), \
59                                    EAIL_TYPE_APP))
60
61 /**
62  * @brief Tests whether given klass is a subclass of EailApp
63  *
64  * @param klass klass object
65  */
66 #define EAIL_IS_APP_CLASS(klass)  (G_TYPE_CHECK_CLASS_TYPE((klass), \
67                                    EAIL_TYPE_APP))
68
69 /**
70  * @brief Gets EailApp class structure from an obj (class instance)
71  *
72  * @param obj object instance to get EailApp class from
73  */
74 #define EAIL_APP_GET_CLASS(obj)   (G_TYPE_INSTANCE_GET_CLASS((obj), \
75                                    EAIL_TYPE_APP, EailAppClass))
76 #ifdef __cplusplus
77 extern "C" {
78 #endif
79
80 /** @brief Definition of object structure for Atk EailApp*/
81 typedef struct _EailApp      EailApp;
82 /** @brief Definition of class structure for Atk EailApp*/
83 typedef struct _EailAppClass EailAppClass;
84
85 /** @brief Definition of object structure for Atk EailBackground*/
86 struct _EailApp
87 {
88    /** @brief Parent AtkObject whose functionality is being extended */
89    AtkObject parent;
90    gint child_count_last;/**< @brief last reported count of children */
91 };
92
93 /** @brief Definition of class structure for Atk EailBackground*/
94 struct _EailAppClass
95 {
96    /** @brief parent class whose functionality is being extended */
97    AtkObjectClass parent_class;
98 };
99
100 /** @brief Getter for EailApp GType
101  *
102  * @returns GType for EailApp implementation*/
103 GType eail_app_get_type(void);
104
105 #ifdef __cplusplus
106 }
107 #endif
108
109 #endif