summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Zaoui <daniel.zaoui@samsung.com>2014-03-20 14:37:43 +0200
committerDaniel Zaoui <daniel.zaoui@samsung.com>2014-03-20 15:19:49 +0200
commit89291d067c7893e7bbc1e264bd40a14dadc13939 (patch)
tree6f2ca184e80e5bf9d8c4b652c0cf213f33c83c08
parent38a7eb4d9c6b92483f07ab655ffcd34bd185ef79 (diff)
downloadelementary-89291d067c7893e7bbc1e264bd40a14dadc13939.tar.gz
Eolian: Integration of Conformant
-rw-r--r--src/lib/Makefile.am8
-rw-r--r--src/lib/elm_conform.c71
-rw-r--r--src/lib/elm_conform_eo.h3
-rw-r--r--src/lib/elm_conformant.eo20
-rw-r--r--src/lib/elm_widget_conform.h6
5 files changed, 49 insertions, 59 deletions
diff --git a/src/lib/Makefile.am b/src/lib/Makefile.am
index 67842c07a..e235fcb25 100644
--- a/src/lib/Makefile.am
+++ b/src/lib/Makefile.am
@@ -571,7 +571,9 @@ BUILT_SOURCES = \
elm_clock.eo.c \
elm_clock.eo.h \
elm_colorselector.eo.c \
- elm_colorselector.eo.h
+ elm_colorselector.eo.h \
+ elm_conformant.eo.c \
+ elm_conformant.eo.h
EXTRA_DIST += \
elm_widget.eo \
@@ -597,7 +599,8 @@ EXTRA_DIST += \
elm_calendar.eo \
elm_check.eo \
elm_clock.eo \
- elm_colorselector.eo
+ elm_colorselector.eo \
+ elm_conformant.eo
nodist_includesunstable_HEADERS = \
elm_widget.eo.h \
@@ -623,5 +626,6 @@ nodist_includesunstable_HEADERS = \
elm_calendar.eo.h \
elm_check.eo.h \
elm_clock.eo.h \
+ elm_conformant.eo.h \
elm_colorselector.eo.h
diff --git a/src/lib/elm_conform.c b/src/lib/elm_conform.c
index 57b097de8..f20a2d087 100644
--- a/src/lib/elm_conform.c
+++ b/src/lib/elm_conform.c
@@ -7,8 +7,6 @@
#include "elm_widget_conform.h"
#include "elm_widget_layout.h"
-EAPI Eo_Op ELM_OBJ_CONFORMANT_BASE_ID = EO_NOOP;
-
#define MY_CLASS ELM_OBJ_CONFORMANT_CLASS
#define MY_CLASS_NAME "Elm_Conformant"
@@ -588,21 +586,19 @@ _on_rotation_changed(void *data,
}
}
-static void
-_elm_conformant_smart_theme(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
+EOLIAN static Eina_Bool
+_elm_conformant_elm_widget_theme_apply(Eo *obj, Elm_Conformant_Data *_pd EINA_UNUSED)
{
- Eina_Bool *ret = va_arg(*list, Eina_Bool *);
- if (ret) *ret = EINA_FALSE;
Eina_Bool int_ret = EINA_FALSE;
eo_do_super(obj, MY_CLASS, elm_obj_widget_theme_apply(&int_ret));
- if (!int_ret) return;
+ if (!int_ret) return EINA_FALSE;
_conformant_parts_swallow(obj);
elm_layout_sizing_eval(obj);
- if (ret) *ret = EINA_TRUE;
+ return EINA_TRUE;
}
// unused now - but meant to be for making sure the focused widget is always
@@ -892,8 +888,8 @@ _on_prop_change(void *data,
#endif
-static void
-_elm_conformant_smart_add(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED)
+EOLIAN static void
+_elm_conformant_evas_smart_add(Eo *obj, Elm_Conformant_Data *_pd EINA_UNUSED)
{
eo_do_super(obj, MY_CLASS, evas_obj_smart_add());
elm_widget_sub_object_parent_add(obj);
@@ -913,11 +909,10 @@ _elm_conformant_smart_add(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNU
elm_layout_sizing_eval(obj);
}
-static void
-_elm_conformant_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
+EOLIAN static void
+_elm_conformant_evas_smart_del(Eo *obj, Elm_Conformant_Data *sd)
{
Evas_Object *top;
- Elm_Conformant_Smart_Data *sd = _pd;
#ifdef HAVE_ELEMENTARY_X
ecore_event_handler_del(sd->prop_hdl);
@@ -935,17 +930,15 @@ _elm_conformant_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
eo_do_super(obj, MY_CLASS, evas_obj_smart_del());
}
-static void
-_elm_conformant_smart_parent_set(Eo *obj, void *_pd, va_list *list)
+EOLIAN static void
+_elm_conformant_elm_widget_parent_set(Eo *obj, Elm_Conformant_Data *sd, Evas_Object *parent)
{
#ifdef HAVE_ELEMENTARY_X
- Evas_Object *parent = va_arg(*list, Evas_Object *);
Evas_Object *top = elm_widget_top_get(parent);
Ecore_X_Window xwin = elm_win_xwindow_get(parent);
if ((xwin) && (!elm_win_inlined_image_object_get(top)))
{
- Elm_Conformant_Smart_Data *sd = _pd;
sd->prop_hdl = ecore_event_handler_add
(ECORE_X_EVENT_WINDOW_PROPERTY, _on_prop_change, obj);
@@ -956,11 +949,10 @@ _elm_conformant_smart_parent_set(Eo *obj, void *_pd, va_list *list)
#endif
}
-static void
-_elm_conformant_smart_content_aliases_get(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list)
+EOLIAN static const Elm_Layout_Part_Alias_Description*
+_elm_conformant_elm_layout_content_aliases_get(Eo *obj EINA_UNUSED, Elm_Conformant_Data *_pd EINA_UNUSED)
{
- const Elm_Layout_Part_Alias_Description **aliases = va_arg(*list, const Elm_Layout_Part_Alias_Description **);
- *aliases = _content_aliases;
+ return _content_aliases;
}
EAPI Evas_Object *
@@ -972,8 +964,8 @@ elm_conformant_add(Evas_Object *parent)
return obj;
}
-static void
-_constructor(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
+EOLIAN static void
+_elm_conformant_eo_base_constructor(Eo *obj, Elm_Conformant_Data *sd)
{
Evas_Object *top;
@@ -981,7 +973,6 @@ _constructor(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
eo_do(obj,
evas_obj_type_set(MY_CLASS_NAME_LEGACY),
evas_obj_smart_callbacks_descriptions_set(_smart_callbacks, NULL));
- Elm_Conformant_Smart_Data *sd = _pd;
top = elm_widget_top_get(obj);
_on_indicator_mode_changed(obj, top, NULL);
@@ -999,37 +990,9 @@ _constructor(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
}
static void
-_class_constructor(Eo_Class *klass)
+_elm_conformant_class_constructor(Eo_Class *klass)
{
- const Eo_Op_Func_Description func_desc[] = {
- EO_OP_FUNC(EO_BASE_ID(EO_BASE_SUB_ID_CONSTRUCTOR), _constructor),
-
- EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_ADD), _elm_conformant_smart_add),
- EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_DEL), _elm_conformant_smart_del),
-
- EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_PARENT_SET), _elm_conformant_smart_parent_set),
- EO_OP_FUNC(ELM_OBJ_WIDGET_ID(ELM_OBJ_WIDGET_SUB_ID_THEME_APPLY), _elm_conformant_smart_theme),
-
- EO_OP_FUNC(ELM_OBJ_LAYOUT_ID(ELM_OBJ_LAYOUT_SUB_ID_CONTENT_ALIASES_GET), _elm_conformant_smart_content_aliases_get),
- EO_OP_FUNC_SENTINEL
- };
- eo_class_funcs_set(klass, func_desc);
-
evas_smart_legacy_type_register(MY_CLASS_NAME_LEGACY, klass);
}
-static const Eo_Op_Description op_desc[] = {
- EO_OP_DESCRIPTION_SENTINEL
-};
-
-static const Eo_Class_Description class_desc = {
- EO_VERSION,
- MY_CLASS_NAME,
- EO_CLASS_TYPE_REGULAR,
- EO_CLASS_DESCRIPTION_OPS(&ELM_OBJ_CONFORMANT_BASE_ID, op_desc, ELM_OBJ_CONFORMANT_SUB_ID_LAST),
- NULL,
- sizeof(Elm_Conformant_Smart_Data),
- _class_constructor,
- NULL
-};
-EO_DEFINE_CLASS(elm_obj_conformant_class_get, &class_desc, ELM_OBJ_LAYOUT_CLASS, NULL);
+#include "elm_conformant.eo.c"
diff --git a/src/lib/elm_conform_eo.h b/src/lib/elm_conform_eo.h
index 0a7aa170d..406c1252d 100644
--- a/src/lib/elm_conform_eo.h
+++ b/src/lib/elm_conform_eo.h
@@ -3,6 +3,8 @@
*
* @{
*/
+#include "elm_conformant.eo.h"
+#if 0
#define ELM_OBJ_CONFORMANT_CLASS elm_obj_conformant_class_get()
const Eo_Class *elm_obj_conformant_class_get(void) EINA_CONST;
@@ -13,6 +15,7 @@ enum
{
ELM_OBJ_CONFORMANT_SUB_ID_LAST
};
+#endif
/**
* @}
*/
diff --git a/src/lib/elm_conformant.eo b/src/lib/elm_conformant.eo
new file mode 100644
index 000000000..e3a9e2b13
--- /dev/null
+++ b/src/lib/elm_conformant.eo
@@ -0,0 +1,20 @@
+class Elm_Conformant (Elm_Layout)
+{
+ eo_prefix: elm_obj_conformant;
+ implements {
+ class::constructor;
+ Eo_Base::constructor;
+ Evas_Smart::add;
+ Evas_Smart::del;
+ Elm_Widget::parent::set;
+ Elm_Widget::theme_apply;
+ Elm_Layout::content_aliases::get;
+ }
+ events {
+ virtualkeypad,state,on;
+ virtualkeypad,state,off;
+ clipboard,state,on;
+ clipboard,state,off;
+ }
+
+}
diff --git a/src/lib/elm_widget_conform.h b/src/lib/elm_widget_conform.h
index 0c46264e1..2ed7a27e1 100644
--- a/src/lib/elm_widget_conform.h
+++ b/src/lib/elm_widget_conform.h
@@ -17,8 +17,8 @@
/**
* Base layout smart data extended with conformant instance data.
*/
-typedef struct _Elm_Conformant_Smart_Data Elm_Conformant_Smart_Data;
-struct _Elm_Conformant_Smart_Data
+typedef struct _Elm_Conformant_Data Elm_Conformant_Data;
+struct _Elm_Conformant_Data
{
Evas_Object *portrait_indicator;
Evas_Object *landscape_indicator;
@@ -62,7 +62,7 @@ enum _Conformant_Part_Type
*/
#define ELM_CONFORMANT_DATA_GET(o, sd) \
- Elm_Conformant_Smart_Data * sd = eo_data_scope_get(o, ELM_OBJ_CONFORMANT_CLASS)
+ Elm_Conformant_Data * sd = eo_data_scope_get(o, ELM_OBJ_CONFORMANT_CLASS)
#define ELM_CONFORMANT_DATA_GET_OR_RETURN(o, ptr) \
ELM_CONFORMANT_DATA_GET(o, ptr); \