jackdanielz pushed a commit to branch master.

commit afce02d30b1daf9b1a2e6a6c27aa29780b3468b0
Author: Daniel Zaoui <[email protected]>
Date:   Sun Apr 28 09:04:28 2013 +0300

    Elementary: Hoversel header split.
---
 src/lib/elc_hoversel.h        | 335 +-----------------------------------------
 src/lib/elc_hoversel_eo.h     | 167 +++++++++++++++++++++
 src/lib/elc_hoversel_legacy.h | 180 +++++++++++++++++++++++
 3 files changed, 353 insertions(+), 329 deletions(-)

diff --git a/src/lib/elc_hoversel.h b/src/lib/elc_hoversel.h
index d74d7cc..5c52f80 100644
--- a/src/lib/elc_hoversel.h
+++ b/src/lib/elc_hoversel.h
@@ -47,335 +47,12 @@
  * @{
  */
 
-#define ELM_OBJ_HOVERSEL_CLASS elm_obj_hoversel_class_get()
-
-const Eo_Class *elm_obj_hoversel_class_get(void) EINA_CONST;
-
-extern EAPI Eo_Op ELM_OBJ_HOVERSEL_BASE_ID;
-
-enum
-{
-   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_SET,
-   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_GET,
-   ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_SET,
-   ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_GET,
-   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_BEGIN,
-   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_END,
-   ELM_OBJ_HOVERSEL_SUB_ID_EXPANDED_GET,
-   ELM_OBJ_HOVERSEL_SUB_ID_CLEAR,
-   ELM_OBJ_HOVERSEL_SUB_ID_ITEMS_GET,
-   ELM_OBJ_HOVERSEL_SUB_ID_ITEM_ADD,
-   ELM_OBJ_HOVERSEL_SUB_ID_LAST
-};
-
-#define ELM_OBJ_HOVERSEL_ID(sub_id) (ELM_OBJ_HOVERSEL_BASE_ID + sub_id)
-
-
-/**
- * @def elm_obj_hoversel_hover_parent_set
- * @since 1.8
- *
- * @brief Set the Hover parent
- *
- * @param[in] parent
- *
- * @see elm_hoversel_hover_parent_set
- */
-#define elm_obj_hoversel_hover_parent_set(parent) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_SET), 
EO_TYPECHECK(Evas_Object *, parent)
-
-/**
- * @def elm_obj_hoversel_hover_parent_get
- * @since 1.8
- *
- * @brief Get the Hover parent
- *
- * @param[out] ret
- *
- * @see elm_hoversel_hover_parent_get
- */
-#define elm_obj_hoversel_hover_parent_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_GET), 
EO_TYPECHECK(Evas_Object **, ret)
-
-/**
- * @def elm_obj_hoversel_horizontal_set
- * @since 1.8
- *
- * @brief This sets the hoversel to expand horizontally.
- *
- * @param[in] horizontal
- *
- * @see elm_hoversel_horizontal_set
- */
-#define elm_obj_hoversel_horizontal_set(horizontal) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_SET), 
EO_TYPECHECK(Eina_Bool, horizontal)
-
-/**
- * @def elm_obj_hoversel_horizontal_get
- * @since 1.8
- *
- * @brief This returns whether the hoversel is set to expand horizontally.
- *
- * @param[out] ret
- *
- * @see elm_hoversel_horizontal_get
- */
-#define elm_obj_hoversel_horizontal_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_GET), 
EO_TYPECHECK(Eina_Bool *, ret)
-
-/**
- * @def elm_obj_hoversel_hover_begin
- * @since 1.8
- *
- * @brief This triggers the hoversel popup from code, the same as if the user
- * had clicked the button.
- *
- *
- * @see elm_hoversel_hover_begin
- */
-#define elm_obj_hoversel_hover_begin() 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_BEGIN)
-
-/**
- * @def elm_obj_hoversel_hover_end
- * @since 1.8
- *
- * @brief This dismisses the hoversel popup as if the user had clicked
- * outside the hover.
- *
- *
- * @see elm_hoversel_hover_end
- */
-#define elm_obj_hoversel_hover_end() 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_END)
-
-/**
- * @def elm_obj_hoversel_expanded_get
- * @since 1.8
- *
- * @brief Returns whether the hoversel is expanded.
- *
- * @param[out] ret
- *
- * @see elm_hoversel_expanded_get
- */
-#define elm_obj_hoversel_expanded_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_EXPANDED_GET), 
EO_TYPECHECK(Eina_Bool *, ret)
-
-/**
- * @def elm_obj_hoversel_clear
- * @since 1.8
- *
- * @brief This will remove all the children items from the hoversel.
- *
- *
- * @see elm_hoversel_clear
- */
-#define elm_obj_hoversel_clear() 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_CLEAR)
-
-/**
- * @def elm_obj_hoversel_items_get
- * @since 1.8
- *
- * @brief Get the list of items within the given hoversel.
- *
- * @param[out] ret
- *
- * @see elm_hoversel_items_get
- */
-#define elm_obj_hoversel_items_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_ITEMS_GET), EO_TYPECHECK(const 
Eina_List **, ret)
-
-/**
- * @def elm_obj_hoversel_item_add
- * @since 1.8
- *
- * @brief Add an item to the hoversel button
- *
- * @param[in] label
- * @param[in] icon_file
- * @param[in] icon_type
- * @param[in] func
- * @param[in] data
- * @param[out] ret
- *
- * @see elm_hoversel_item_add
- */
-#define elm_obj_hoversel_item_add(label, icon_file, icon_type, func, data, 
ret) ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_ITEM_ADD), EO_TYPECHECK(const 
char *, label), EO_TYPECHECK(const char *, icon_file), 
EO_TYPECHECK(Elm_Icon_Type, icon_type), EO_TYPECHECK(Evas_Smart_Cb, func), 
EO_TYPECHECK(const void *, data), EO_TYPECHECK(Elm_Object_Item **, ret)
-
-/**
- * @brief Add a new Hoversel object
- *
- * @param parent The parent object
- * @return The new object or NULL if it cannot be created
- *
- * @ingroup Hoversel
- */
-EAPI Evas_Object                 *elm_hoversel_add(Evas_Object *parent);
-
-/**
- * @brief This sets the hoversel to expand horizontally.
- *
- * @param obj The hoversel object
- * @param horizontal If true, the hover will expand horizontally to the
- * right.
- *
- * @note The initial button will display horizontally regardless of this
- * setting.
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_horizontal_set(Evas_Object 
*obj, Eina_Bool horizontal);
-
-/**
- * @brief This returns whether the hoversel is set to expand horizontally.
- *
- * @param obj The hoversel object
- * @return If true, the hover will expand horizontally to the right.
- *
- * @see elm_hoversel_horizontal_set()
- *
- * @ingroup Hoversel
- */
-EAPI Eina_Bool                    elm_hoversel_horizontal_get(const 
Evas_Object *obj);
-
-/**
- * @brief Set the Hover parent
- *
- * @param obj The hoversel object
- * @param parent The parent to use
- *
- * Sets the hover parent object, the area that will be darkened when the
- * hoversel is clicked. Should probably be the window that the hoversel is
- * in. See @ref Hover objects for more information.
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_hover_parent_set(Evas_Object 
*obj, Evas_Object *parent);
-
-/**
- * @brief Get the Hover parent
- *
- * @param obj The hoversel object
- * @return The used parent
- *
- * Gets the hover parent object.
- *
- * @see elm_hoversel_hover_parent_set()
- *
- * @ingroup Hoversel
- */
-EAPI Evas_Object                 *elm_hoversel_hover_parent_get(const 
Evas_Object *obj);
-
-/**
- * @brief This triggers the hoversel popup from code, the same as if the user
- * had clicked the button.
- *
- * @param obj The hoversel object
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_hover_begin(Evas_Object *obj);
-
-/**
- * @brief This dismisses the hoversel popup as if the user had clicked
- * outside the hover.
- *
- * @param obj The hoversel object
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_hover_end(Evas_Object *obj);
-
-/**
- * @brief Returns whether the hoversel is expanded.
- *
- * @param obj The hoversel object
- * @return  This will return EINA_TRUE if the hoversel is expanded or
- * EINA_FALSE if it is not expanded.
- *
- * @ingroup Hoversel
- */
-EAPI Eina_Bool                    elm_hoversel_expanded_get(const Evas_Object 
*obj);
-
-/**
- * @brief This will remove all the children items from the hoversel.
- *
- * @param obj The hoversel object
- *
- * @warning Should @b not be called while the hoversel is active; use
- * elm_hoversel_expanded_get() to check first.
- *
- * @see elm_object_item_del()
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_clear(Evas_Object *obj);
-
-/**
- * @brief Get the list of items within the given hoversel.
- *
- * @param obj The hoversel object
- * @return Returns a list of Elm_Object_Item*
- *
- * @see elm_hoversel_item_add()
- *
- * @ingroup Hoversel
- */
-EAPI const Eina_List             *elm_hoversel_items_get(const Evas_Object 
*obj);
-
-/**
- * @brief Add an item to the hoversel button
- *
- * @param obj The hoversel object
- * @param label The text label to use for the item (NULL if not desired)
- * @param icon_file An image file path on disk to use for the icon or standard
- * icon name (NULL if not desired)
- * @param icon_type The icon type if relevant
- * @param func Convenience function to call when this item is selected
- * @param data Data to pass to item-related functions
- * @return A handle to the item added.
- *
- * This adds an item to the hoversel to show when it is clicked. Note: if you
- * need to use an icon from an edje file then use
- * elm_hoversel_item_icon_set() right after this function, and set
- * icon_file to NULL here.
- *
- * For more information on what @p icon_file and @p icon_type are, see the
- * @ref Icon "icon documentation".
- *
- * @ingroup Hoversel
- */
-EAPI Elm_Object_Item             *elm_hoversel_item_add(Evas_Object *obj, 
const char *label, const char *icon_file, Elm_Icon_Type icon_type, 
Evas_Smart_Cb func, const void *data);
-
-/**
- * @brief This sets the icon for the given hoversel item.
- *
- * @param it The item to set the icon
- * @param icon_file An image file path on disk to use for the icon or standard
- * icon name
- * @param icon_group The edje group to use if @p icon_file is an edje file. 
Set this
- * to NULL if the icon is not an edje file
- * @param icon_type The icon type
- *
- * The icon can be loaded from the standard set, from an image file, or from
- * an edje file.
- *
- * @see elm_hoversel_item_add()
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_item_icon_set(Elm_Object_Item 
*it, const char *icon_file, const char *icon_group, Elm_Icon_Type icon_type);
-
-/**
- * @brief Get the icon object of the hoversel item
- *
- * @param it The item to get the icon from
- * @param icon_file The image file path on disk used for the icon or standard
- * icon name
- * @param icon_group The edje group used if @p icon_file is an edje file. NULL
- * if the icon is not an edje file
- * @param icon_type The icon type
- *
- * @see elm_hoversel_item_icon_set()
- * @see elm_hoversel_item_add()
- *
- * @ingroup Hoversel
- */
-EAPI void                         elm_hoversel_item_icon_get(const 
Elm_Object_Item *it, const char **icon_file, const char **icon_group, 
Elm_Icon_Type *icon_type);
-
+#ifdef EFL_EO_API_SUPPORT
+#include "elc_hoversel_eo.h"
+#endif
+#ifndef EFL_NOLEGACY_API_SUPPORT
+#include "elc_hoversel_legacy.h"
+#endif
 /**
  * @}
  */
diff --git a/src/lib/elc_hoversel_eo.h b/src/lib/elc_hoversel_eo.h
new file mode 100644
index 0000000..5489416
--- /dev/null
+++ b/src/lib/elc_hoversel_eo.h
@@ -0,0 +1,167 @@
+#define ELM_OBJ_HOVERSEL_CLASS elm_obj_hoversel_class_get()
+
+const Eo_Class *elm_obj_hoversel_class_get(void) EINA_CONST;
+
+extern EAPI Eo_Op ELM_OBJ_HOVERSEL_BASE_ID;
+
+enum
+{
+   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_SET,
+   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_GET,
+   ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_SET,
+   ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_GET,
+   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_BEGIN,
+   ELM_OBJ_HOVERSEL_SUB_ID_HOVER_END,
+   ELM_OBJ_HOVERSEL_SUB_ID_EXPANDED_GET,
+   ELM_OBJ_HOVERSEL_SUB_ID_CLEAR,
+   ELM_OBJ_HOVERSEL_SUB_ID_ITEMS_GET,
+   ELM_OBJ_HOVERSEL_SUB_ID_ITEM_ADD,
+   ELM_OBJ_HOVERSEL_SUB_ID_LAST
+};
+
+#define ELM_OBJ_HOVERSEL_ID(sub_id) (ELM_OBJ_HOVERSEL_BASE_ID + sub_id)
+
+
+/**
+ * @def elm_obj_hoversel_hover_parent_set
+ * @since 1.8
+ *
+ * @brief Set the Hover parent
+ *
+ * @param[in] parent
+ *
+ * @see elm_hoversel_hover_parent_set
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_hover_parent_set(parent) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_SET), 
EO_TYPECHECK(Evas_Object *, parent)
+
+/**
+ * @def elm_obj_hoversel_hover_parent_get
+ * @since 1.8
+ *
+ * @brief Get the Hover parent
+ *
+ * @param[out] ret
+ *
+ * @see elm_hoversel_hover_parent_get
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_hover_parent_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_PARENT_GET), 
EO_TYPECHECK(Evas_Object **, ret)
+
+/**
+ * @def elm_obj_hoversel_horizontal_set
+ * @since 1.8
+ *
+ * @brief This sets the hoversel to expand horizontally.
+ *
+ * @param[in] horizontal
+ *
+ * @see elm_hoversel_horizontal_set
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_horizontal_set(horizontal) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_SET), 
EO_TYPECHECK(Eina_Bool, horizontal)
+
+/**
+ * @def elm_obj_hoversel_horizontal_get
+ * @since 1.8
+ *
+ * @brief This returns whether the hoversel is set to expand horizontally.
+ *
+ * @param[out] ret
+ *
+ * @see elm_hoversel_horizontal_get
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_horizontal_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HORIZONTAL_GET), 
EO_TYPECHECK(Eina_Bool *, ret)
+
+/**
+ * @def elm_obj_hoversel_hover_begin
+ * @since 1.8
+ *
+ * @brief This triggers the hoversel popup from code, the same as if the user
+ * had clicked the button.
+ *
+ *
+ * @see elm_hoversel_hover_begin
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_hover_begin() 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_BEGIN)
+
+/**
+ * @def elm_obj_hoversel_hover_end
+ * @since 1.8
+ *
+ * @brief This dismisses the hoversel popup as if the user had clicked
+ * outside the hover.
+ *
+ *
+ * @see elm_hoversel_hover_end
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_hover_end() 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_HOVER_END)
+
+/**
+ * @def elm_obj_hoversel_expanded_get
+ * @since 1.8
+ *
+ * @brief Returns whether the hoversel is expanded.
+ *
+ * @param[out] ret
+ *
+ * @see elm_hoversel_expanded_get
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_expanded_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_EXPANDED_GET), 
EO_TYPECHECK(Eina_Bool *, ret)
+
+/**
+ * @def elm_obj_hoversel_clear
+ * @since 1.8
+ *
+ * @brief This will remove all the children items from the hoversel.
+ *
+ *
+ * @see elm_hoversel_clear
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_clear() 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_CLEAR)
+
+/**
+ * @def elm_obj_hoversel_items_get
+ * @since 1.8
+ *
+ * @brief Get the list of items within the given hoversel.
+ *
+ * @param[out] ret
+ *
+ * @see elm_hoversel_items_get
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_items_get(ret) 
ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_ITEMS_GET), EO_TYPECHECK(const 
Eina_List **, ret)
+
+/**
+ * @def elm_obj_hoversel_item_add
+ * @since 1.8
+ *
+ * @brief Add an item to the hoversel button
+ *
+ * @param[in] label
+ * @param[in] icon_file
+ * @param[in] icon_type
+ * @param[in] func
+ * @param[in] data
+ * @param[out] ret
+ *
+ * @see elm_hoversel_item_add
+ *
+ * @ingroup Hoversel
+ */
+#define elm_obj_hoversel_item_add(label, icon_file, icon_type, func, data, 
ret) ELM_OBJ_HOVERSEL_ID(ELM_OBJ_HOVERSEL_SUB_ID_ITEM_ADD), EO_TYPECHECK(const 
char *, label), EO_TYPECHECK(const char *, icon_file), 
EO_TYPECHECK(Elm_Icon_Type, icon_type), EO_TYPECHECK(Evas_Smart_Cb, func), 
EO_TYPECHECK(const void *, data), EO_TYPECHECK(Elm_Object_Item **, ret)
diff --git a/src/lib/elc_hoversel_legacy.h b/src/lib/elc_hoversel_legacy.h
new file mode 100644
index 0000000..02509c3
--- /dev/null
+++ b/src/lib/elc_hoversel_legacy.h
@@ -0,0 +1,180 @@
+/**
+ * @brief Add a new Hoversel object
+ *
+ * @param parent The parent object
+ * @return The new object or NULL if it cannot be created
+ *
+ * @ingroup Hoversel
+ */
+EAPI Evas_Object                 *elm_hoversel_add(Evas_Object *parent);
+
+/**
+ * @brief This sets the hoversel to expand horizontally.
+ *
+ * @param obj The hoversel object
+ * @param horizontal If true, the hover will expand horizontally to the
+ * right.
+ *
+ * @note The initial button will display horizontally regardless of this
+ * setting.
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_horizontal_set(Evas_Object 
*obj, Eina_Bool horizontal);
+
+/**
+ * @brief This returns whether the hoversel is set to expand horizontally.
+ *
+ * @param obj The hoversel object
+ * @return If true, the hover will expand horizontally to the right.
+ *
+ * @see elm_hoversel_horizontal_set()
+ *
+ * @ingroup Hoversel
+ */
+EAPI Eina_Bool                    elm_hoversel_horizontal_get(const 
Evas_Object *obj);
+
+/**
+ * @brief Set the Hover parent
+ *
+ * @param obj The hoversel object
+ * @param parent The parent to use
+ *
+ * Sets the hover parent object, the area that will be darkened when the
+ * hoversel is clicked. Should probably be the window that the hoversel is
+ * in. See @ref Hover objects for more information.
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_hover_parent_set(Evas_Object 
*obj, Evas_Object *parent);
+
+/**
+ * @brief Get the Hover parent
+ *
+ * @param obj The hoversel object
+ * @return The used parent
+ *
+ * Gets the hover parent object.
+ *
+ * @see elm_hoversel_hover_parent_set()
+ *
+ * @ingroup Hoversel
+ */
+EAPI Evas_Object                 *elm_hoversel_hover_parent_get(const 
Evas_Object *obj);
+
+/**
+ * @brief This triggers the hoversel popup from code, the same as if the user
+ * had clicked the button.
+ *
+ * @param obj The hoversel object
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_hover_begin(Evas_Object *obj);
+
+/**
+ * @brief This dismisses the hoversel popup as if the user had clicked
+ * outside the hover.
+ *
+ * @param obj The hoversel object
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_hover_end(Evas_Object *obj);
+
+/**
+ * @brief Returns whether the hoversel is expanded.
+ *
+ * @param obj The hoversel object
+ * @return  This will return EINA_TRUE if the hoversel is expanded or
+ * EINA_FALSE if it is not expanded.
+ *
+ * @ingroup Hoversel
+ */
+EAPI Eina_Bool                    elm_hoversel_expanded_get(const Evas_Object 
*obj);
+
+/**
+ * @brief This will remove all the children items from the hoversel.
+ *
+ * @param obj The hoversel object
+ *
+ * @warning Should @b not be called while the hoversel is active; use
+ * elm_hoversel_expanded_get() to check first.
+ *
+ * @see elm_object_item_del()
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_clear(Evas_Object *obj);
+
+/**
+ * @brief Get the list of items within the given hoversel.
+ *
+ * @param obj The hoversel object
+ * @return Returns a list of Elm_Object_Item*
+ *
+ * @see elm_hoversel_item_add()
+ *
+ * @ingroup Hoversel
+ */
+EAPI const Eina_List             *elm_hoversel_items_get(const Evas_Object 
*obj);
+
+/**
+ * @brief Add an item to the hoversel button
+ *
+ * @param obj The hoversel object
+ * @param label The text label to use for the item (NULL if not desired)
+ * @param icon_file An image file path on disk to use for the icon or standard
+ * icon name (NULL if not desired)
+ * @param icon_type The icon type if relevant
+ * @param func Convenience function to call when this item is selected
+ * @param data Data to pass to item-related functions
+ * @return A handle to the item added.
+ *
+ * This adds an item to the hoversel to show when it is clicked. Note: if you
+ * need to use an icon from an edje file then use
+ * elm_hoversel_item_icon_set() right after this function, and set
+ * icon_file to NULL here.
+ *
+ * For more information on what @p icon_file and @p icon_type are, see the
+ * @ref Icon "icon documentation".
+ *
+ * @ingroup Hoversel
+ */
+EAPI Elm_Object_Item             *elm_hoversel_item_add(Evas_Object *obj, 
const char *label, const char *icon_file, Elm_Icon_Type icon_type, 
Evas_Smart_Cb func, const void *data);
+
+/**
+ * @brief This sets the icon for the given hoversel item.
+ *
+ * @param it The item to set the icon
+ * @param icon_file An image file path on disk to use for the icon or standard
+ * icon name
+ * @param icon_group The edje group to use if @p icon_file is an edje file. 
Set this
+ * to NULL if the icon is not an edje file
+ * @param icon_type The icon type
+ *
+ * The icon can be loaded from the standard set, from an image file, or from
+ * an edje file.
+ *
+ * @see elm_hoversel_item_add()
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_item_icon_set(Elm_Object_Item 
*it, const char *icon_file, const char *icon_group, Elm_Icon_Type icon_type);
+
+/**
+ * @brief Get the icon object of the hoversel item
+ *
+ * @param it The item to get the icon from
+ * @param icon_file The image file path on disk used for the icon or standard
+ * icon name
+ * @param icon_group The edje group used if @p icon_file is an edje file. NULL
+ * if the icon is not an edje file
+ * @param icon_type The icon type
+ *
+ * @see elm_hoversel_item_icon_set()
+ * @see elm_hoversel_item_add()
+ *
+ * @ingroup Hoversel
+ */
+EAPI void                         elm_hoversel_item_icon_get(const 
Elm_Object_Item *it, const char **icon_file, const char **icon_group, 
Elm_Icon_Type *icon_type);

-- 

------------------------------------------------------------------------------
Try New Relic Now & We'll Send You this Cool Shirt
New Relic is the only SaaS-based application performance monitoring service 
that delivers powerful full stack analytics. Optimize and monitor your
browser, app, & servers with just a few lines of code. Try New Relic
and get this awesome Nerd Life shirt! http://p.sf.net/sfu/newrelic_d2d_apr

Reply via email to