From d7ff6085c2a098099471b4617bfe6400a6b91243 Mon Sep 17 00:00:00 2001 From: Yossi Kantor Date: Sun, 6 Apr 2014 13:42:36 +0300 Subject: [PATCH] Eolian: Legacy integration of Edje --- src/Makefile_Edje.am | 8 +- src/lib/edje/Edje_Eo.h | 2294 +-------------------------------------- src/lib/edje/Edje_Legacy.h | 2588 +------------------------------------------- 3 files changed, 43 insertions(+), 4847 deletions(-) diff --git a/src/Makefile_Edje.am b/src/Makefile_Edje.am index c0e261e..467ace5 100644 --- a/src/Makefile_Edje.am +++ b/src/Makefile_Edje.am @@ -4,8 +4,10 @@ BUILT_SOURCES += \ lib/edje/edje.eo.c \ lib/edje/edje.eo.h \ + lib/edje/edje.eo.legacy.h \ lib/edje/edje_edit.eo.c \ - lib/edje/edje_edit.eo.h + lib/edje/edje_edit.eo.h \ + lib/edje/edje_edit.eo.legacy.h edjeeolianfilesdir = $(datadir)/eolian/include/edje-@VMAJ@ @@ -39,7 +41,9 @@ lib/edje/Edje_Edit.h nodist_installed_edjemainheaders_DATA = \ lib/edje/edje.eo.h \ - lib/edje/edje_edit.eo.h + lib/edje/edje_edit.eo.h \ + lib/edje/edje.eo.legacy.h \ + lib/edje/edje_edit.eo.legacy.h lib_edje_libedje_la_SOURCES = \ lib/edje/edje_private.h \ diff --git a/src/lib/edje/Edje_Eo.h b/src/lib/edje/Edje_Eo.h index 9078fcc..fec56d9 100644 --- a/src/lib/edje/Edje_Eo.h +++ b/src/lib/edje/Edje_Eo.h @@ -1,2294 +1,2 @@ #include "edje.eo.h" -#if 0 -#define EDJE_OBJ_CLASS edje_object_class_get() - -const Eo_Class *edje_object_class_get(void) EINA_CONST; - -extern EAPI Eo_Op EDJE_OBJ_BASE_ID; - -enum -{ - EDJE_OBJ_SUB_ID_SCALE_SET, - EDJE_OBJ_SUB_ID_SCALE_GET, - EDJE_OBJ_SUB_ID_MIRRORED_GET, - EDJE_OBJ_SUB_ID_MIRRORED_SET, - EDJE_OBJ_SUB_ID_DATA_GET, - EDJE_OBJ_SUB_ID_FREEZE, - EDJE_OBJ_SUB_ID_THAW, - EDJE_OBJ_SUB_ID_COLOR_CLASS_SET, - EDJE_OBJ_SUB_ID_COLOR_CLASS_GET, - EDJE_OBJ_SUB_ID_TEXT_CLASS_SET, - EDJE_OBJ_SUB_ID_PART_EXISTS, - EDJE_OBJ_SUB_ID_PART_OBJECT_GET, - EDJE_OBJ_SUB_ID_PART_GEOMETRY_GET, - EDJE_OBJ_SUB_ID_ITEM_PROVIDER_SET, - EDJE_OBJ_SUB_ID_TEXT_CHANGE_CB_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_STYLE_USER_PUSH, - EDJE_OBJ_SUB_ID_PART_TEXT_STYLE_USER_POP, - EDJE_OBJ_SUB_ID_PART_TEXT_STYLE_USER_PEEK, - EDJE_OBJ_SUB_ID_PART_TEXT_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_ESCAPED_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_UNESCAPED_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_UNESCAPED_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECTION_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_NONE, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_ALL, - EDJE_OBJ_SUB_ID_PART_TEXT_INSERT, - EDJE_OBJ_SUB_ID_PART_TEXT_APPEND, - EDJE_OBJ_SUB_ID_PART_TEXT_ANCHOR_LIST_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_ANCHOR_GEOMETRY_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_ITEM_LIST_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_ITEM_GEOMETRY_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_GEOMETRY_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_USER_INSERT, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_ALLOW_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_ABORT, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_BEGIN, - EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_EXTEND, - EDJE_OBJ_SUB_ID_PART_TEXT_IMF_CONTEXT_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_NEXT, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_PREV, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_UP, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_DOWN, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_BEGIN_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_END_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_COPY, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_LINE_BEGIN_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_LINE_END_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_COORD_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_IS_FORMAT_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_IS_VISIBLE_FORMAT_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_CONTENT_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_POS_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_POS_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_IMF_CONTEXT_RESET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_VARIATION_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_VARIATION_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_AUTOCAPITAL_TYPE_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_AUTOCAPITAL_TYPE_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_PREDICTION_ALLOW_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_PREDICTION_ALLOW_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_ENABLED_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_ENABLED_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_SHOW, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_HIDE, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LANGUAGE_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LANGUAGE_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_IMDATA_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_IMDATA_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_TYPE_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_TYPE_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_DISABLED_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_DISABLED_GET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_SHOW_ON_DEMAND_SET, - EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_SHOW_ON_DEMAND_GET, - EDJE_OBJ_SUB_ID_TEXT_INSERT_FILTER_CALLBACK_ADD, - EDJE_OBJ_SUB_ID_TEXT_INSERT_FILTER_CALLBACK_DEL, - EDJE_OBJ_SUB_ID_TEXT_INSERT_FILTER_CALLBACK_DEL_FULL, - EDJE_OBJ_SUB_ID_TEXT_MARKUP_FILTER_CALLBACK_ADD, - EDJE_OBJ_SUB_ID_TEXT_MARKUP_FILTER_CALLBACK_DEL, - EDJE_OBJ_SUB_ID_TEXT_MARKUP_FILTER_CALLBACK_DEL_FULL, - EDJE_OBJ_SUB_ID_PART_SWALLOW, - EDJE_OBJ_SUB_ID_PART_UNSWALLOW, - EDJE_OBJ_SUB_ID_PART_SWALLOW_GET, - EDJE_OBJ_SUB_ID_SIZE_MIN_GET, - EDJE_OBJ_SUB_ID_SIZE_MAX_GET, - EDJE_OBJ_SUB_ID_CALC_FORCE, - EDJE_OBJ_SUB_ID_SIZE_MIN_CALC, - EDJE_OBJ_SUB_ID_PARTS_EXTENDS_CALC, - EDJE_OBJ_SUB_ID_SIZE_MIN_RESTRICTED_CALC, - EDJE_OBJ_SUB_ID_PART_STATE_GET, - EDJE_OBJ_SUB_ID_PART_DRAG_DIR_GET, - EDJE_OBJ_SUB_ID_PART_DRAG_VALUE_SET, - EDJE_OBJ_SUB_ID_PART_DRAG_VALUE_GET, - EDJE_OBJ_SUB_ID_PART_DRAG_SIZE_SET, - EDJE_OBJ_SUB_ID_PART_DRAG_SIZE_GET, - EDJE_OBJ_SUB_ID_PART_DRAG_STEP_SET, - EDJE_OBJ_SUB_ID_PART_DRAG_STEP_GET, - EDJE_OBJ_SUB_ID_PART_DRAG_PAGE_SET, - EDJE_OBJ_SUB_ID_PART_DRAG_PAGE_GET, - EDJE_OBJ_SUB_ID_PART_DRAG_STEP, - EDJE_OBJ_SUB_ID_PART_DRAG_PAGE, - EDJE_OBJ_SUB_ID_PART_BOX_APPEND, - EDJE_OBJ_SUB_ID_PART_BOX_PREPEND, - EDJE_OBJ_SUB_ID_PART_BOX_INSERT_BEFORE, - EDJE_OBJ_SUB_ID_PART_BOX_INSERT_AT, - EDJE_OBJ_SUB_ID_PART_BOX_REMOVE, - EDJE_OBJ_SUB_ID_PART_BOX_REMOVE_AT, - EDJE_OBJ_SUB_ID_PART_BOX_REMOVE_ALL, - EDJE_OBJ_SUB_ID_ACCESS_PART_LIST_GET, - EDJE_OBJ_SUB_ID_PART_TABLE_CHILD_GET, - EDJE_OBJ_SUB_ID_PART_TABLE_PACK, - EDJE_OBJ_SUB_ID_PART_TABLE_UNPACK, - EDJE_OBJ_SUB_ID_PART_TABLE_COL_ROW_SIZE_GET, - EDJE_OBJ_SUB_ID_PART_TABLE_CLEAR, - EDJE_OBJ_SUB_ID_PERSPECTIVE_SET, - EDJE_OBJ_SUB_ID_PERSPECTIVE_GET, - EDJE_OBJ_SUB_ID_PRELOAD, - EDJE_OBJ_SUB_ID_UPDATE_HINTS_SET, - EDJE_OBJ_SUB_ID_UPDATE_HINTS_GET, - - EDJE_OBJ_SUB_ID_PART_EXTERNAL_OBJECT_GET, - EDJE_OBJ_SUB_ID_PART_EXTERNAL_PARAM_SET, - EDJE_OBJ_SUB_ID_PART_EXTERNAL_PARAM_GET, - EDJE_OBJ_SUB_ID_PART_EXTERNAL_CONTENT_GET, - EDJE_OBJ_SUB_ID_PART_EXTERNAL_PARAM_TYPE_GET, - - EDJE_OBJ_SUB_ID_FILE_SET, - EDJE_OBJ_SUB_ID_MMAP_SET, - EDJE_OBJ_SUB_ID_FILE_GET, - EDJE_OBJ_SUB_ID_LOAD_ERROR_GET, - - EDJE_OBJ_SUB_ID_MESSAGE_SEND, - EDJE_OBJ_SUB_ID_MESSAGE_HANDLER_SET, - EDJE_OBJ_SUB_ID_MESSAGE_SIGNAL_PROCESS, - - EDJE_OBJ_SUB_ID_SIGNAL_CALLBACK_ADD, - EDJE_OBJ_SUB_ID_SIGNAL_CALLBACK_DEL, - EDJE_OBJ_SUB_ID_SIGNAL_EMIT, - EDJE_OBJ_SUB_ID_PLAY_SET, - EDJE_OBJ_SUB_ID_PLAY_GET, - EDJE_OBJ_SUB_ID_ANIMATION_SET, - EDJE_OBJ_SUB_ID_ANIMATION_GET, - - EDJE_OBJ_SUB_ID_LAST -}; - -#define EDJE_OBJ_ID(sub_id) (EDJE_OBJ_BASE_ID + sub_id) - -/** - * @ingroup Edje_Object_Scale - * - * @{ - */ - -/** - * @def edje_obj_scale_set - * @since 1.8 - * - * @brief Set the scaling factor for a given Edje object. - * - * @param[in] scale - * @param[out] ret - * - * @see edje_object_scale_set - */ -#define edje_obj_scale_set(scale, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SCALE_SET), EO_TYPECHECK(double, scale), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_scale_get - * @since 1.8 - * - * @brief Get a given Edje object's scaling factor. - * - * @param[out] ret - * - * @see edje_object_scale_get - */ -#define edje_obj_scale_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SCALE_GET), EO_TYPECHECK(double *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Text_Entry - * - * @{ - */ - -/** - * @def edje_obj_mirrored_get - * @since 1.8 - * - * @brief Get the RTL orientation for this object. - * - * @param[out] ret - * - * @see edje_object_mirrored_get - */ -#define edje_obj_mirrored_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_MIRRORED_GET), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_mirrored_set - * @since 1.8 - * - * @brief Set the RTL orientation for this object. - * - * @param[in] rtl - * - * @see edje_object_mirrored_set - */ -#define edje_obj_mirrored_set(rtl) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_MIRRORED_SET), EO_TYPECHECK(Eina_Bool, rtl) - -/** - * @def edje_obj_item_provider_set - * @since 1.8 - * - * @brief Set the function that provides item objects for named items in an edje entry text - * - * @param[in] func - * @param[in] data - * - * @see edje_object_item_provider_set - */ -#define edje_obj_item_provider_set(func, data) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_ITEM_PROVIDER_SET), EO_TYPECHECK(Edje_Item_Provider_Cb, func), EO_TYPECHECK(void *, data) - -/** - * @def edje_obj_part_text_imf_context_reset - * @since 1.8 - * - * @brief Reset the input method context if needed. - * - * @param[in] part - * - * @see edje_object_part_text_imf_context_reset - */ -#define edje_obj_part_text_imf_context_reset(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_IMF_CONTEXT_RESET), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_imf_context_get - * @since 1.8 - * - * @brief Get the input method context in entry. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_imf_context_get - */ -#define edje_obj_part_text_imf_context_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_IMF_CONTEXT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(void **, ret) - -/** - * @def edje_obj_part_text_input_panel_layout_set - * @since 1.8 - * - * @brief Set the layout of the input panel. - * - * @param[in] part - * @param[in] layout - * - * @see edje_object_part_text_input_panel_layout_set - */ -#define edje_obj_part_text_input_panel_layout_set(part, layout) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Input_Panel_Layout, layout) - -/** - * @def edje_obj_part_text_input_panel_layout_get - * @since 1.8 - * - * @brief Get the layout of the input panel. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_layout_get - */ -#define edje_obj_part_text_input_panel_layout_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Input_Panel_Layout *, ret) - -/** - * @def edje_obj_part_text_input_panel_variation_get - * @since 1.8 - * - * @brief Get the layout variation of the input panel. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_variation_get - */ -#define edje_obj_part_text_input_panel_layout_variation_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_VARIATION_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(int *, ret) - -/** - * @def edje_obj_part_text_input_panel_variation_set - * @since 1.8 - * - * @brief Set the layout variation of the input panel. - * - * @param[in] part - * @param[in] variation - * - * @see edje_object_part_text_input_panel_variation_get - */ -#define edje_obj_part_text_input_panel_layout_variation_set(part, variation) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LAYOUT_VARIATION_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(int, variation) - -/** - * @def edje_obj_part_text_autocapital_type_set - * @since 1.8 - * - * @brief Set the autocapitalization type on the immodule. - * - * @param[in] part - * @param[in] autocapital_type - * - * @see edje_object_part_text_autocapital_type_set - */ -#define edje_obj_part_text_autocapital_type_set(part, autocapital_type) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_AUTOCAPITAL_TYPE_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Text_Autocapital_Type, autocapital_type) - -/** - * @def edje_obj_part_text_autocapital_type_get - * @since 1.8 - * - * @brief Retrieves the autocapitalization type - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_autocapital_type_get - */ -#define edje_obj_part_text_autocapital_type_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_AUTOCAPITAL_TYPE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Text_Autocapital_Type *, ret) - -/** - * @def edje_obj_part_text_prediction_allow_set - * @since 1.8 - * - * @brief Set whether the prediction is allowed or not. - * - * @param[in] part - * @param[in] prediction - * - * @see edje_object_part_text_prediction_allow_set - */ -#define edje_obj_part_text_prediction_allow_set(part, prediction) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_PREDICTION_ALLOW_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, prediction) - -/** - * @def edje_obj_part_text_prediction_allow_get - * @since 1.8 - * - * @brief Get whether the prediction is allowed or not. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_prediction_allow_get - */ -#define edje_obj_part_text_prediction_allow_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_PREDICTION_ALLOW_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_input_panel_enabled_set - * @since 1.8 - * - * @brief Sets the attribute to show the input panel automatically. - * - * @param[in] part - * @param[in] enabled - * - * @see edje_object_part_text_input_panel_enabled_set - */ -#define edje_obj_part_text_input_panel_enabled_set(part, enabled) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_ENABLED_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, enabled) - -/** - * @def edje_obj_part_text_input_panel_enabled_get - * @since 1.8 - * - * @brief Retrieve the attribute to show the input panel automatically. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_enabled_get - */ -#define edje_obj_part_text_input_panel_enabled_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_ENABLED_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_input_panel_show - * @since 1.8 - * - * @brief Show the input panel (virtual keyboard) based on the input panel property such as layout, autocapital types, and so on. - * - * @param[in] part - * - * @see edje_object_part_text_input_panel_show - */ -#define edje_obj_part_text_input_panel_show(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_SHOW), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_input_panel_hide - * @since 1.8 - * - * @brief Hide the input panel (virtual keyboard). - * - * @param[in] part - * - * @see edje_object_part_text_input_panel_hide - */ -#define edje_obj_part_text_input_panel_hide(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_HIDE), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_input_panel_language_set - * @since 1.8 - * - * Set the language mode of the input panel. - * - * @param[in] part - * @param[in] lang - * - * @see edje_object_part_text_input_panel_language_set - */ -#define edje_obj_part_text_input_panel_language_set(part, lang) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LANGUAGE_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Input_Panel_Lang, lang) - -/** - * @def edje_obj_part_text_input_panel_language_get - * @since 1.8 - * - * Get the language mode of the input panel. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_language_get - */ -#define edje_obj_part_text_input_panel_language_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_LANGUAGE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Input_Panel_Lang *, ret) - -/** - * @def edje_obj_part_text_input_panel_imdata_set - * @since 1.8 - * - * Set the input panel-specific data to deliver to the input panel. - * - * @param[in] part - * @param[in] data - * @param[in] len - * - * @see edje_object_part_text_input_panel_imdata_set - */ -#define edje_obj_part_text_input_panel_imdata_set(part, data, len) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_IMDATA_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const void *, data), EO_TYPECHECK(int, len) - -/** - * @def edje_obj_part_text_input_panel_imdata_get - * @since 1.8 - * - * Get the specific data of the current active input panel. - * - * @param[in] part - * @param[in] data - * @param[in] len - * - * @see edje_object_part_text_input_panel_imdata_get - */ -#define edje_obj_part_text_input_panel_imdata_get(part, data, len) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_IMDATA_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(void *, data), EO_TYPECHECK(int *, len) - -/** - * @def edje_obj_part_text_input_panel_return_key_type_set - * @since 1.8 - * - * Set the "return" key type. This type is used to set string or icon on the "return" key of the input panel. - * - * @param[in] part - * @param[out] return_key_type - * - * @see edje_object_part_text_input_panel_return_key_type_set - */ -#define edje_obj_part_text_input_panel_return_key_type_set(part, return_key_type) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_TYPE_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Input_Panel_Return_Key_Type, return_key_type) - -/** - * @def edje_obj_part_text_input_panel_return_key_type_get - * @since 1.8 - * - * Get the "return" key type. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_return_key_type_get - */ -#define edje_obj_part_text_input_panel_return_key_type_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_TYPE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Input_Panel_Return_Key_Type *, ret) - -/** - * @def edje_obj_part_text_input_panel_return_key_disabled_set - * @since 1.8 - * - * Set the return key on the input panel to be disabled. - * - * @param[in] part - * @param[in] disabled - * - * @see edje_object_part_text_input_panel_return_key_disabled_set - */ -#define edje_obj_part_text_input_panel_return_key_disabled_set(part, disabled) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_DISABLED_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, disabled) - -/** - * @def edje_obj_part_text_input_panel_return_key_disabled_get - * @since 1.8 - * - * Get whether the return key on the input panel should be disabled or not. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_return_key_disabled_get - */ -#define edje_obj_part_text_input_panel_return_key_disabled_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_RETURN_KEY_DISABLED_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_input_panel_show_on_demand_set - * @since 1.9 - * - * @brief Set the attribute to show the input panel in case of only an user's explicit Mouse Up event. - * - * @param[in] part - * @param[in] ondemand - * - * @see edje_object_part_text_input_panel_show_on_demand_set - */ -#define edje_obj_part_text_input_panel_show_on_demand_set(part, ondemand) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_SHOW_ON_DEMAND_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, ondemand) - -/** - * @def edje_obj_part_text_input_panel_show_on_demand_get - * @since 1.9 - * - * @brief Get the attribute to show the input panel in case of only an user's explicit Mouse Up event. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_input_panel_show_on_demand_get - */ -#define edje_obj_part_text_input_panel_show_on_demand_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INPUT_PANEL_SHOW_ON_DEMAND_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_text_insert_filter_callback_add - * @since 1.8 - * - * Add a filter function for newly inserted text. - * - * @param[in] part - * @param[in] func - * @param[in] data - * - * @see edje_object_text_insert_filter_callback_add - */ -#define edje_obj_text_insert_filter_callback_add(part, func, data) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_INSERT_FILTER_CALLBACK_ADD), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Text_Filter_Cb, func), EO_TYPECHECK(void *, data) - -/** - * @def edje_obj_text_insert_filter_callback_del - * @since 1.8 - * - * Delete a function from the filter list. - * - * @param[in] part - * @param[in] func - * @param[out] ret - * - * @see edje_object_text_insert_filter_callback_del - */ -#define edje_obj_text_insert_filter_callback_del(part, func, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_INSERT_FILTER_CALLBACK_DEL), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Text_Filter_Cb, func), EO_TYPECHECK(void **, ret) - -/** - * @def edje_obj_text_insert_filter_callback_del_full - * @since 1.8 - * - * Delete a function and matching user data from the filter list. - * - * @param[in] part - * @param[in] func - * @param[in] data - * @param[out] ret - * - * @see edje_object_text_insert_filter_callback_del_full - */ -#define edje_obj_text_insert_filter_callback_del_full(part, func, data, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_INSERT_FILTER_CALLBACK_DEL_FULL), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Text_Filter_Cb, func), EO_TYPECHECK(void *, data), EO_TYPECHECK(void **, ret) - -/** - * @def edje_obj_text_markup_filter_callback_add - * @since 1.8 - * - * Add a markup filter function for newly inserted text. - * - * @param[in] part - * @param[in] func - * @param[in] data - * - * @see edje_object_text_markup_filter_callback_add - */ -#define edje_obj_text_markup_filter_callback_add(part, func, data) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_MARKUP_FILTER_CALLBACK_ADD), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Markup_Filter_Cb, func), EO_TYPECHECK(void *, data) - -/** - * @def edje_obj_text_markup_filter_callback_del - * @since 1.8 - * - * Delete a function from the markup filter list. - * - * @param[in] part - * @param[in] func - * @param[out] ret - * - * @see edje_object_text_markup_filter_callback_del - */ -#define edje_obj_text_markup_filter_callback_del(part, func, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_MARKUP_FILTER_CALLBACK_DEL), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Markup_Filter_Cb, func), EO_TYPECHECK(void **, ret) - -/** - * @def edje_obj_text_markup_filter_callback_del_full - * @since 1.8 - * - * Delete a function and matching user data from the markup filter list. - * - * @param[in] part - * @param[in] func - * @param[in] data - * @param[out] ret - * - * @see edje_object_text_markup_filter_callback_del_full - */ -#define edje_obj_text_markup_filter_callback_del_full(part, func, data, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_MARKUP_FILTER_CALLBACK_DEL_FULL), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Markup_Filter_Cb, func), EO_TYPECHECK(void *, data), EO_TYPECHECK(void **, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_File - * - * @{ - */ - -/** - * @def edje_obj_data_get - * @since 1.8 - * - * @brief Retrieve an EDC data field's value from a given Edje. - * - * @param[in] key - * @param[out] ret - * - * @see edje_object_data_get - */ -#define edje_obj_data_get(key, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_DATA_GET), EO_TYPECHECK(const char *, key), EO_TYPECHECK(const char **, ret) - -/** - * @def edje_obj_file_set - * @since 1.8 - * - * @param[in] file in - * @param[in] group in - * @param[out] ret out - * - * @see edje_object_file_set - */ -#define edje_obj_file_set(file, group, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_FILE_SET), EO_TYPECHECK(const char*, file), EO_TYPECHECK(const char *, group), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_mmap_set - * @since 1.8 - * - * @param[in] file in - * @param[in] group in - * @param[out] ret out - * - * @see edje_object_file_set - */ -#define edje_obj_mmap_set(file, group, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_MMAP_SET), EO_TYPECHECK(const Eina_File*, file), EO_TYPECHECK(const char *, group), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_file_get - * @since 1.8 - * - * @brief Get the file and group name that a given Edje object is bound to - * - * @param[out] file - * @param[out] group - * - * @see edje_object_file_get - */ -#define edje_obj_file_get(file, group) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_FILE_GET), EO_TYPECHECK(const char **, file), EO_TYPECHECK(const char **, group) - -/** - * @def edje_obj_load_error_get - * @since 1.8 - * - * @brief Gets the (last) file loading error for a given Edje object - * - * @param[out] ret - * - * @see edje_object_load_error_get - */ -#define edje_obj_load_error_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_LOAD_ERROR_GET), EO_TYPECHECK(Edje_Load_Error *, ret) -/** - * @} - */ - -/** - * @ingroup Edje_Object_Animation - * - * @{ - */ - -/** - * @def edje_obj_play_set - * @since 1.8 - * - * @brief Set the Edje object to playing or paused states. - * - * @param[in] play - * - * @see edje_object_play_set - */ -#define edje_obj_play_set(play) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PLAY_SET), EO_TYPECHECK(Eina_Bool, play) - -/** - * @def edje_obj_play_get - * @since 1.8 - * - * @brief Get the Edje object's state. - * - * @param[out] ret - * - * @see edje_object_play_get - */ -#define edje_obj_play_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PLAY_GET), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_animation_set - * @since 1.8 - * - * @brief Set the object's animation state. - * - * @param[in] on - * - * @see edje_object_animation_set - */ -#define edje_obj_animation_set(on) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_ANIMATION_SET), EO_TYPECHECK(Eina_Bool, on) - -/** - * @def edje_obj_animation_get - * @since 1.8 - * - * @brief Get the Edje object's animation state. - * - * @param[out] ret - * - * @see edje_object_animation_get - */ -#define edje_obj_animation_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_ANIMATION_GET), EO_TYPECHECK(Eina_Bool *, ret) -/** - * @def edje_obj_freeze - * @since 1.8 - * - * @brief Freezes the Edje object. - * - * @param[out] ret - * - * @see edje_object_freeze - */ -#define edje_obj_freeze(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_FREEZE), EO_TYPECHECK(int *, ret) - -/** - * @def edje_obj_thaw - * @since 1.8 - * - * @brief Thaws the Edje object. - * - * @param[out] ret - * - * @see edje_object_thaw - */ -#define edje_obj_thaw(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_THAW), EO_TYPECHECK(int *, ret) - -/** - * @def edje_obj_part_state_get - * @since 1.8 - * - * @brief Returns the state of the Edje part. - * - * @param[in] part - * @param[out] val_ret - * @param[out] ret - * - * @see edje_object_part_state_get - */ -#define edje_obj_part_state_get(part, val_ret, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_STATE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double *, val_ret), EO_TYPECHECK(const char **, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Color_Class - * - * @{ - */ - -/** - * @def edje_obj_color_class_set - * @since 1.8 - * - * @brief Sets the object color class. - * - * @param[in] color_class - * @param[in] r - * @param[in] g - * @param[in] b - * @param[in] a - * @param[in] r2 - * @param[in] g2 - * @param[in] b2 - * @param[in] a2 - * @param[in] r3 - * @param[in] g3 - * @param[in] b3 - * @param[in] a3 - * @param[out] ret - * - * @see edje_object_color_class_set - */ -#define edje_obj_color_class_set(color_class, r, g, b, a, r2, g2, b2, a2, r3, g3, b3, a3, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_COLOR_CLASS_SET), EO_TYPECHECK(const char *, color_class), EO_TYPECHECK(int, r), EO_TYPECHECK(int, g), EO_TYPECHECK(int, b), EO_TYPECHECK(int, a), EO_TYPECHECK(int, r2), EO_TYPECHECK(int, g2), EO_TYPECHECK(int, b2), EO_TYPECHECK(int, a2), EO_TYPECHECK(int, r3), EO_TYPECHECK(int, g3), EO_TYPECHECK(int, b3), EO_TYPECHECK(int, a3), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_color_class_get - * @since 1.8 - * - * @brief Gets the object color class. - * - * @param[in] color_class - * @param[out] r - * @param[out] g - * @param[out] b - * @param[out] a - * @param[out] r2 - * @param[out] g2 - * @param[out] b2 - * @param[out] a2 - * @param[out] r3 - * @param[out] g3 - * @param[out] b3 - * @param[out] a3 - * @param[out] ret - * - * @see edje_object_color_class_get - */ -#define edje_obj_color_class_get(color_class, r, g, b, a, r2, g2, b2, a2, r3, g3, b3, a3, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_COLOR_CLASS_GET), EO_TYPECHECK(const char *, color_class), EO_TYPECHECK(int *, r), EO_TYPECHECK(int *, g), EO_TYPECHECK(int *, b), EO_TYPECHECK(int *, a), EO_TYPECHECK(int *, r2), EO_TYPECHECK(int *, g2), EO_TYPECHECK(int *, b2), EO_TYPECHECK(int *, a2), EO_TYPECHECK(int *, r3), EO_TYPECHECK(int *, g3), EO_TYPECHECK(int *, b3), EO_TYPECHECK(int *, a3), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Text_Class - * - * @{ - */ - -/** - * @def edje_obj_text_class_set - * @since 1.8 - * - * @brief Sets Edje text class. - * - * @param[in] text_class - * @param[in] font - * @param[in] size - * @param[out] ret - * - * @see edje_object_text_class_set - */ -#define edje_obj_text_class_set(text_class, font, size, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_CLASS_SET), EO_TYPECHECK(const char *, text_class), EO_TYPECHECK(const char *, font), EO_TYPECHECK(Evas_Font_Size, size), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Part - * - * @{ - */ - -/** - * @def edje_obj_part_exists - * @since 1.8 - * - * @brief Check if an Edje part exists in a given Edje object's group - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_exists - */ -#define edje_obj_part_exists(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_EXISTS), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_object_get - * @since 1.8 - * - * @brief Get a handle to the Evas object implementing a given Edje - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_object_get - */ -#define edje_obj_part_object_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_OBJECT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const Evas_Object **, ret) - -/** - * @def edje_obj_part_geometry_get - * @since 1.8 - * - * @brief Retrieve the geometry of a given Edje part, in a given Edje - * - * @param[in] part - * @param[out] x - * @param[out] y - * @param[out] w - * @param[out] h - * @param[out] ret - * - * @see edje_object_part_geometry_get - */ -#define edje_obj_part_geometry_get(part, x, y, w, h, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_GEOMETRY_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Coord *, x), EO_TYPECHECK(Evas_Coord *, y), EO_TYPECHECK(Evas_Coord *, w), EO_TYPECHECK(Evas_Coord *, h), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_access_part_list_get - * @since 1.8 - * - * @brief Retrieve a list all accessibility part names - * - * @param[out] ret - * - * @see edje_object_access_part_list_get - */ -#define edje_obj_access_part_list_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_ACCESS_PART_LIST_GET), EO_TYPECHECK(Eina_List **, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Text - * - * @{ - */ - -/** - * @def edje_obj_text_change_cb_set - * @since 1.8 - * - * @brief Set the object text callback. - * - * @param[in] func - * @param[in] data - * - * @see edje_object_text_change_cb_set - */ -#define edje_obj_text_change_cb_set(func, data) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_TEXT_CHANGE_CB_SET), EO_TYPECHECK(Edje_Text_Change_Cb, func), EO_TYPECHECK(void *, data) - -/** - * @def edje_obj_part_text_style_user_push - * @since 1.8 - * - * @brief Set the style of the part. - * - * @param[in] part - * @param[in] style - * - * @see edje_object_part_text_style_user_push - */ -#define edje_obj_part_text_style_user_push(part, style) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_STYLE_USER_PUSH), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, style) - -/** - * @def edje_obj_part_text_style_user_pop - * @since 1.8 - * - * @brief Delete the top style form the user style stack. - * - * @param[in] part - * - * @see edje_object_part_text_style_user_pop - */ -#define edje_obj_part_text_style_user_pop(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_STYLE_USER_POP), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_style_user_peek - * @since 1.8 - * - * @brief Return the text of the object part. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_style_user_peek - */ -#define edje_obj_part_text_style_user_peek(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_STYLE_USER_PEEK), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char **, ret) - -/** - * @def edje_obj_part_text_set - * @since 1.8 - * - * @brief Sets the text for an object part - * - * @param[in] part - * @param[in] text - * @param[out] ret - * - * @see edje_object_part_text_set - */ -#define edje_obj_part_text_set(part, text, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, text), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_get - * @since 1.8 - * - * @brief Return the text of the object part. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_get - */ -#define edje_obj_part_text_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char **, ret) - -/** - * @def edje_obj_part_text_escaped_set - * @since 1.8 - * - * @brief Sets the text for an object part, but converts HTML escapes to UTF8 - * - * @param[in] part - * @param[in] text - * @param[out] ret - * - * @see edje_object_part_text_escaped_set - */ -#define edje_obj_part_text_escaped_set(part, text, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_ESCAPED_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, text), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_unescaped_set - * @since 1.8 - * - * @brief Sets the raw (non escaped) text for an object part. - * - * @param[in] part - * @param[in] text_to_escape - * @param[out] ret - * - * @see edje_object_part_text_unescaped_set - */ -#define edje_obj_part_text_unescaped_set(part, text_to_escape, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_UNESCAPED_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, text_to_escape), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_unescaped_get - * @since 1.8 - * - * @brief Returns the text of the object part, without escaping. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_unescaped_get - */ -#define edje_obj_part_text_unescaped_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_UNESCAPED_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(char **, ret) - -/** - * @def edje_obj_part_text_insert - * @since 1.8 - * - * @brief Insert text for an object part. - * - * @param[in] part - * @param[in] text - * - * @see edje_object_part_text_insert - */ -#define edje_obj_part_text_insert(part, text) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_INSERT), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, text) - -/** - * @def edje_obj_part_text_append - * @since 1.8 - * - * @brief Insert text for an object part. - * - * @param[in] part - * @param[in] text - * - * @see edje_object_part_text_append - */ -#define edje_obj_part_text_append(part, text) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_APPEND), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, text) - -/** - * @def edje_obj_part_text_anchor_list_get - * @since 1.8 - * - * @brief Return a list of char anchor names. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_anchor_list_get - */ -#define edje_obj_part_text_anchor_list_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_ANCHOR_LIST_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const Eina_List **, ret) - -/** - * @def edje_obj_part_text_anchor_geometry_get - * @since 1.8 - * - * @brief Return a list of Evas_Textblock_Rectangle anchor rectangles. - * - * @param[in] part - * @param[in] anchor - * @param[out] ret - * - * @see edje_object_part_text_anchor_geometry_get - */ -#define edje_obj_part_text_anchor_geometry_get(part, anchor, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_ANCHOR_GEOMETRY_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, anchor), EO_TYPECHECK(const Eina_List **, ret) - -/** - * @def edje_obj_part_text_item_list_get - * @since 1.8 - * - * @brief Return a list of char item names. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_item_list_get - */ -#define edje_obj_part_text_item_list_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_ITEM_LIST_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const Eina_List **, ret) - -/** - * @def edje_obj_part_text_item_geometry_get - * @since 1.8 - * - * @brief Return item geometry. - * - * @param[in] part - * @param[in] item - * @param[out] cx - * @param[out] cy - * @param[out] cw - * @param[out] ch - * @param[out] ret - * - * @see edje_object_part_text_item_geometry_get - */ -#define edje_obj_part_text_item_geometry_get(part, item, cx, cy, cw, ch, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_ITEM_GEOMETRY_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, item), EO_TYPECHECK(Evas_Coord *, cx), EO_TYPECHECK(Evas_Coord *, cy), EO_TYPECHECK(Evas_Coord *, cw), EO_TYPECHECK(Evas_Coord *, ch), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_user_insert - * @since 1.8 - * - * @brief This function inserts text as if the user has inserted it. - * - * @param[in] part - * @param[in] text - * - * @see edje_object_part_text_user_insert - */ -#define edje_obj_part_text_user_insert(part, text) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_USER_INSERT), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, text) - -/** - * @} - */ - -/** - * @ingroup Edje_Text_Selection - * - * @{ - */ - -/** - * @def edje_obj_part_text_selection_get - * @since 1.8 - * - * @brief Return the selection text of the object part. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_text_selection_get - */ -#define edje_obj_part_text_selection_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECTION_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char **, ret) - -/** - * @def edje_obj_part_text_select_none - * @since 1.8 - * - * @brief Set the selection to be none. - * - * @param[in] part - * - * @see edje_object_part_text_select_none - */ -#define edje_obj_part_text_select_none(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_NONE), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_select_all - * @since 1.8 - * - * @brief Set the selection to be everything. - * - * @param[in] part - * - * @see edje_object_part_text_select_all - */ -#define edje_obj_part_text_select_all(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_ALL), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_select_allow_set - * @since 1.8 - * - * @brief Enables selection if the entry is an EXPLICIT selection mode - * - * @param[in] part - * @param[in] allow - * - * @see edje_object_part_text_select_allow_set - */ -#define edje_obj_part_text_select_allow_set(part, allow) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_ALLOW_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, allow) - -/** - * @def edje_obj_part_text_select_abort - * @since 1.8 - * - * @brief Aborts any selection action on a part. - * - * @param[in] part - * - * @see edje_object_part_text_select_abort - */ -#define edje_obj_part_text_select_abort(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_ABORT), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_select_begin - * @since 1.8 - * - * @brief Starts selecting at current cursor position - * - * @param[in] part - * - * @see edje_object_part_text_select_begin - */ -#define edje_obj_part_text_select_begin(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_BEGIN), EO_TYPECHECK(const char *, part) - -/** - * @def edje_obj_part_text_select_extend - * @since 1.8 - * - * @brief Extends the current selection to the current cursor position - * - * @param[in] part - * - * @see edje_object_part_text_select_extend - */ -#define edje_obj_part_text_select_extend(part) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_SELECT_EXTEND), EO_TYPECHECK(const char *, part) - -/** - * @} - */ - -/** - * @ingroup Edje_Text_Cursor - * - * @{ - */ - -/** - * @def edje_obj_part_text_cursor_next - * @since 1.8 - * - * @brief Advances the cursor to the next cursor position. - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_next - */ -#define edje_obj_part_text_cursor_next(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_NEXT), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_prev - * @since 1.8 - * - * @brief Moves the cursor to the previous char - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_prev - */ -#define edje_obj_part_text_cursor_prev(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_PREV), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_up - * @since 1.8 - * - * @brief Move the cursor to the char above the current cursor position. - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_up - */ -#define edje_obj_part_text_cursor_up(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_UP), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_down - * @since 1.8 - * - * @brief Moves the cursor to the char below the current cursor position. - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_down - */ -#define edje_obj_part_text_cursor_down(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_DOWN), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_begin_set - * @since 1.8 - * - * @brief Moves the cursor to the beginning of the text part - * - * @param[in] part - * @param[in] cur - * - * @see edje_object_part_text_cursor_begin_set - */ -#define edje_obj_part_text_cursor_begin_set(part, cur) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_BEGIN_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur) - -/** - * @def edje_obj_part_text_cursor_end_set - * @since 1.8 - * - * @brief Moves the cursor to the end of the text part. - * - * @param[in] part - * @param[in] cur - * - * @see edje_object_part_text_cursor_end_set - */ -#define edje_obj_part_text_cursor_end_set(part, cur) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_END_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur) - -/** - * @def edje_obj_part_text_cursor_copy - * @since 1.8 - * - * @brief Copy the cursor to another cursor. - * - * @param[in] part - * @param[in] src - * @param[in] dst - * - * @see edje_object_part_text_cursor_copy - */ -#define edje_obj_part_text_cursor_copy(part, src, dst) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_COPY), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, src), EO_TYPECHECK(Edje_Cursor, dst) - -/** - * @def edje_obj_part_text_cursor_line_begin_set - * @since 1.8 - * - * @brief Move the cursor to the beginning of the line. - * - * @param[in] part - * @param[in] cur - * - * @see edje_object_part_text_cursor_line_begin_set - */ -#define edje_obj_part_text_cursor_line_begin_set(part, cur) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_LINE_BEGIN_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur) - -/** - * @def edje_obj_part_text_cursor_line_end_set - * @since 1.8 - * - * @brief Move the cursor to the end of the line. - * - * @param[in] part - * @param[in] cur - * - * @see edje_object_part_text_cursor_line_end_set - */ -#define edje_obj_part_text_cursor_line_end_set(part, cur) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_LINE_END_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur) - -/** - * @def edje_obj_part_text_cursor_coord_set - * @since 1.8 - * - * Position the given cursor to a X,Y position. - * - * @param[in] part - * @param[in] cur - * @param[in] x - * @param[in] y - * @param[out] ret - * - * @see edje_object_part_text_cursor_coord_set - */ -#define edje_obj_part_text_cursor_coord_set(part, cur, x, y, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_COORD_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Evas_Coord, x), EO_TYPECHECK(Evas_Coord, y), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_is_format_get - * @since 1.8 - * - * @brief Returns whether the cursor points to a format. - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_is_format_get - */ -#define edje_obj_part_text_cursor_is_format_get(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_IS_FORMAT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_is_visible_format_get - * @since 1.8 - * - * @brief Return true if the cursor points to a visible format - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_is_visible_format_get - */ -#define edje_obj_part_text_cursor_is_visible_format_get(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_IS_VISIBLE_FORMAT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_text_cursor_content_get - * @since 1.8 - * - * @brief Returns the content (char) at the cursor position. - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_content_get - */ -#define edje_obj_part_text_cursor_content_get(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_CONTENT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(char **, ret) - -/** - * @def edje_obj_part_text_cursor_pos_set - * @since 1.8 - * - * @brief Sets the cursor position to the given value - * - * @param[in] part - * @param[in] cur - * @param[in] pos - * - * @see edje_object_part_text_cursor_pos_set - */ -#define edje_obj_part_text_cursor_pos_set(part, cur, pos) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_POS_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(int, pos) - -/** - * @def edje_obj_part_text_cursor_pos_get - * @since 1.8 - * - * @brief Retrieves the current position of the cursor - * - * @param[in] part - * @param[in] cur - * @param[out] ret - * - * @see edje_object_part_text_cursor_pos_get - */ -#define edje_obj_part_text_cursor_pos_get(part, cur, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_POS_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Cursor, cur), EO_TYPECHECK(int *, ret) - -/** - * @def edje_obj_part_text_cursor_geometry_get - * @since 1.8 - * - * @brief Returns the cursor geometry of the part relative to the edje - * - * @param[in] part - * @param[out] x - * @param[out] y - * @param[out] w - * @param[out] h - * - * @see edje_object_part_text_cursor_geometry_get - */ -#define edje_obj_part_text_cursor_geometry_get(part, x, y, w, h) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TEXT_CURSOR_GEOMETRY_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Coord *, x), EO_TYPECHECK(Evas_Coord *, y), EO_TYPECHECK(Evas_Coord *, w), EO_TYPECHECK(Evas_Coord *, h) - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Swallow - * - * @{ - */ - -/** - * @def edje_obj_part_swallow - * @since 1.8 - * - * @brief "Swallows" an object into one of the Edje object SWALLOW - * - * @param[in] part - * @param[in] obj_swallow - * @param[out] ret - * - * @see edje_object_part_swallow - */ -#define edje_obj_part_swallow(part, obj_swallow, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_SWALLOW), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, obj_swallow), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_unswallow - * @since 1.8 - * - * @brief Unswallow an object. - * - * @param[in] obj_swallow - * - * @see edje_object_part_unswallow - */ -#define edje_obj_part_unswallow(obj_swallow) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_UNSWALLOW), EO_TYPECHECK(Evas_Object *, obj_swallow) - -/** - * @def edje_obj_part_swallow_get - * @since 1.8 - * - * @brief Get the object currently swallowed by a part. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_swallow_get - */ -#define edje_obj_part_swallow_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_SWALLOW_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object **, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Geometry_Group - * - * @{ - */ - -/** - * @def edje_obj_size_min_get - * @since 1.8 - * - * @brief Get the minimum size specified -- as an EDC property -- for a - * given Edje object - * - * @param[out] minw - * @param[out] minh - * - * @see edje_object_size_min_get - */ -#define edje_obj_size_min_get(minw, minh) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIZE_MIN_GET), EO_TYPECHECK(Evas_Coord *, minw), EO_TYPECHECK(Evas_Coord *, minh) - -/** - * @def edje_obj_update_hints_set - * @since 1.8 - * - * @brief Edje will automatically update the size hints on itself. - * - * @param[in] update - * - * @see edje_object_update_hints_set - */ -#define edje_obj_update_hints_set(update) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_UPDATE_HINTS_SET), EO_TYPECHECK(Eina_Bool, update) - -/** - * @def edje_obj_update_hints_get - * @since 1.8 - * - * @brief Whether or not Edje will update size hints on itself. - * - * @param[out] ret - * - * @see edje_object_update_hints_get - */ -#define edje_obj_update_hints_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_UPDATE_HINTS_GET), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_size_max_get - * @since 1.8 - * - * @brief Get the maximum size specified -- as an EDC property -- for a - * given Edje object - * - * @param[out] maxw - * @param[out] maxh - * - * @see edje_object_size_max_get - */ -#define edje_obj_size_max_get(maxw, maxh) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIZE_MAX_GET), EO_TYPECHECK(Evas_Coord *, maxw), EO_TYPECHECK(Evas_Coord *, maxh) - -/** - * @def edje_obj_calc_force - * @since 1.8 - * - * @brief Force a Size/Geometry calculation. - * - * - * @see edje_object_calc_force - */ -#define edje_obj_calc_force() EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_CALC_FORCE) - -/** - * @def edje_obj_size_min_calc - * @since 1.8 - * - * @brief Calculate the minimum required size for a given Edje object. - * - * @param[out] minw - * @param[out] minh - * - * @see edje_object_size_min_calc - */ -#define edje_obj_size_min_calc(minw, minh) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIZE_MIN_CALC), EO_TYPECHECK(Evas_Coord *, minw), EO_TYPECHECK(Evas_Coord *, minh) - -/** - * @def edje_obj_parts_extends_calc - * @since 1.8 - * - * Calculate the geometry of the region, relative to a given Edje - * - * @param[out] x - * @param[out] y - * @param[out] w - * @param[out] h - * @param[out] ret - * - * @see edje_object_parts_extends_calc - */ -#define edje_obj_parts_extends_calc(x, y, w, h, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PARTS_EXTENDS_CALC), EO_TYPECHECK(Evas_Coord *, x), EO_TYPECHECK(Evas_Coord *, y), EO_TYPECHECK(Evas_Coord *, w), EO_TYPECHECK(Evas_Coord *, h), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_size_min_restricted_calc - * @since 1.8 - * - * @brief Calculate the minimum required size for a given Edje object. - * - * @param[out] minw - * @param[out] minh - * @param[in] restrictedw - * @param[in] restrictedh - * - * @see edje_object_size_min_restricted_calc - */ -#define edje_obj_size_min_restricted_calc(minw, minh, restrictedw, restrictedh) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIZE_MIN_RESTRICTED_CALC), EO_TYPECHECK(Evas_Coord *, minw), EO_TYPECHECK(Evas_Coord *, minh), EO_TYPECHECK(Evas_Coord, restrictedw), EO_TYPECHECK(Evas_Coord, restrictedh) - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Drag - * - * @{ - */ - -/** - * @def edje_obj_part_drag_dir_get - * @since 1.8 - * - * @brief Determine dragable directions. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_drag_dir_get - */ -#define edje_obj_part_drag_dir_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_DIR_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_Drag_Dir *, ret) - -/** - * @def edje_obj_part_drag_value_set - * @since 1.8 - * - * @brief Set the dragable object location. - * - * @param[in] part - * @param[in] dx - * @param[in] dy - * @param[out] ret - * - * @see edje_object_part_drag_value_set - */ -#define edje_obj_part_drag_value_set(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_VALUE_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double, dx), EO_TYPECHECK(double, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_value_get - * @since 1.8 - * - * @brief Get the dragable object location. - * - * @param[in] part - * @param[out] dx - * @param[out] dy - * @param[out] ret - * - * @see edje_object_part_drag_value_get - */ -#define edje_obj_part_drag_value_get(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_VALUE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double *, dx), EO_TYPECHECK(double *, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_size_set - * @since 1.8 - * - * @brief Set the dragable object size. - * - * @param[in] part - * @param[in] dw - * @param[in] dh - * @param[out] ret - * - * @see edje_object_part_drag_size_set - */ -#define edje_obj_part_drag_size_set(part, dw, dh, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_SIZE_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double, dw), EO_TYPECHECK(double, dh), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_size_get - * @since 1.8 - * - * @brief Get the dragable object size. - * - * @param[in] part - * @param[out] dw - * @param[out] dh - * @param[out] ret - * - * @see edje_object_part_drag_size_get - */ -#define edje_obj_part_drag_size_get(part, dw, dh, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_SIZE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double *, dw), EO_TYPECHECK(double *, dh), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_step_set - * @since 1.8 - * - * @brief Sets the drag step increment. - * - * @param[in] part - * @param[in] dx - * @param[in] dy - * @param[out] ret - * - * @see edje_object_part_drag_step_set - */ -#define edje_obj_part_drag_step_set(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_STEP_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double, dx), EO_TYPECHECK(double, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_step_get - * @since 1.8 - * - * @brief Gets the drag step increment values. - * - * @param[in] part - * @param[out] dx - * @param[out] dy - * @param[out] ret - * - * @see edje_object_part_drag_step_get - */ -#define edje_obj_part_drag_step_get(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_STEP_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double *, dx), EO_TYPECHECK(double *, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_page_set - * @since 1.8 - * - * @brief Sets the page step increments. - * - * @param[in] part - * @param[in] dx - * @param[in] dy - * @param[out] ret - * - * @see edje_object_part_drag_page_set - */ -#define edje_obj_part_drag_page_set(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_PAGE_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double, dx), EO_TYPECHECK(double, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_page_get - * @since 1.8 - * - * @brief Gets the page step increments. - * - * @param[in] part - * @param[out] dx - * @param[out] dy - * @param[out] ret - * - * @see edje_object_part_drag_page_get - */ -#define edje_obj_part_drag_page_get(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_PAGE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double *, dx), EO_TYPECHECK(double *, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_step - * @since 1.8 - * - * @brief Steps the dragable x,y steps. - * - * @param[in] part - * @param[in] dx - * @param[in] dy - * @param[out] ret - * - * @see edje_object_part_drag_step - */ -#define edje_obj_part_drag_step(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_STEP), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double, dx), EO_TYPECHECK(double, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_drag_page - * @since 1.8 - * - * @brief Pages x,y steps. - * - * @param[in] part - * @param[in] dx - * @param[in] dy - * @param[out] ret - * - * @see edje_object_part_drag_page - */ -#define edje_obj_part_drag_page(part, dx, dy, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_DRAG_PAGE), EO_TYPECHECK(const char *, part), EO_TYPECHECK(double, dx), EO_TYPECHECK(double, dy), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Box - * - * @{ - */ - -/** - * @def edje_obj_part_box_append - * @since 1.8 - * - * @brief Appends an object to the box. - * - * @param[in] part - * @param[in] child - * @param[out] ret - * - * @see edje_object_part_box_append - */ -#define edje_obj_part_box_append(part, child, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_APPEND), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_box_prepend - * @since 1.8 - * - * @brief Prepends an object to the box. - * - * @param[in] part - * @param[in] child - * @param[out] ret - * - * @see edje_object_part_box_prepend - */ -#define edje_obj_part_box_prepend(part, child, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_PREPEND), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_box_insert_before - * @since 1.8 - * - * @brief Adds an object to the box. - * - * @param[in] part - * @param[in] child - * @param[in] reference - * @param[out] ret - * - * @see edje_object_part_box_insert_before - */ -#define edje_obj_part_box_insert_before(part, child, reference, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_INSERT_BEFORE), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child), EO_TYPECHECK(const Evas_Object *, reference), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_box_insert_at - * @since 1.8 - * - * @brief Inserts an object to the box. - * - * @param[in] part - * @param[in] child - * @param[in] pos - * @param[out] ret - * - * @see edje_object_part_box_insert_at - */ -#define edje_obj_part_box_insert_at(part, child, pos, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_INSERT_AT), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child), EO_TYPECHECK(unsigned int, pos), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_box_remove - * @since 1.8 - * - * @brief Removes an object from the box. - * - * @param[in] part - * @param[in] child - * @param[out] ret - * - * @see edje_object_part_box_remove - */ -#define edje_obj_part_box_remove(part, child, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_REMOVE), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child), EO_TYPECHECK(Evas_Object **, ret) - -/** - * @def edje_obj_part_box_remove_at - * @since 1.8 - * - * @brief Removes an object from the box. - * - * @param[in] part - * @param[in] pos - * @param[out] ret - * - * @see edje_object_part_box_remove_at - */ -#define edje_obj_part_box_remove_at(part, pos, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_REMOVE_AT), EO_TYPECHECK(const char *, part), EO_TYPECHECK(unsigned int, pos), EO_TYPECHECK(Evas_Object **, ret) - -/** - * @def edje_obj_part_box_remove_all - * @since 1.8 - * - * @brief Removes all elements from the box. - * - * @param[in] part - * @param[in] clear - * @param[out] ret - * - * @see edje_object_part_box_remove_all - */ -#define edje_obj_part_box_remove_all(part, clear, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_BOX_REMOVE_ALL), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, clear), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Table - * - * @{ - */ - -/** - * @def edje_obj_part_table_child_get - * @since 1.8 - * - * @brief Retrieve a child from a table - * - * @param[in] part - * @param[in] col - * @param[in] row - * @param[out] ret - * - * @see edje_object_part_table_child_get - */ -#define edje_obj_part_table_child_get(part, col, row, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TABLE_CHILD_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(unsigned int, col), EO_TYPECHECK(unsigned int, row), EO_TYPECHECK(Evas_Object **, ret) - -/** - * @def edje_obj_part_table_pack - * @since 1.8 - * - * @brief Packs an object into the table. - * - * @param[in] part - * @param[in] child_obj - * @param[in] col - * @param[in] row - * @param[in] colspan - * @param[in] rowspan - * @param[out] ret - * - * @see edje_object_part_table_pack - */ -#define edje_obj_part_table_pack(part, child_obj, col, row, colspan, rowspan, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TABLE_PACK), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child_obj), EO_TYPECHECK(unsigned short, col), EO_TYPECHECK(unsigned short, row), EO_TYPECHECK(unsigned short, colspan), EO_TYPECHECK(unsigned short, rowspan), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_table_unpack - * @since 1.8 - * - * @brief Removes an object from the table. - * - * @param[in] part - * @param[in] child_obj - * @param[out] ret - * - * @see edje_object_part_table_unpack - */ -#define edje_obj_part_table_unpack(part, child_obj, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TABLE_UNPACK), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object *, child_obj), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_table_col_row_size_get - * @since 1.8 - * - * @brief Gets the number of columns and rows the table has. - * - * @param[in] part - * @param[out] cols - * @param[out] rows - * @param[out] ret - * - * @see edje_object_part_table_col_row_size_get - */ -#define edje_obj_part_table_col_row_size_get(part, cols, rows, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TABLE_COL_ROW_SIZE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(int *, cols), EO_TYPECHECK(int *, rows), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_table_clear - * @since 1.8 - * - * @brief Removes all object from the table. - * - * @param[in] part - * @param[in] clear - * @param[out] ret - * - * @see edje_object_part_table_clear - */ -#define edje_obj_part_table_clear(part, clear, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_TABLE_CLEAR), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Eina_Bool, clear), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Perspective - * - * @{ - */ - -/** - * @def edje_obj_perspective_set - * @since 1.8 - * - * Set the given perspective object on this Edje object. - * - * @param[in] ps - * - * @see edje_object_perspective_set - */ -#define edje_obj_perspective_set(ps) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PERSPECTIVE_SET), EO_TYPECHECK(Edje_Perspective *, ps) - -/** - * @def edje_obj_perspective_get - * @since 1.8 - * - * Get the current perspective used on this Edje object. - * - * @param[out] ret - * - * @see edje_object_perspective_get - */ -#define edje_obj_perspective_get(ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PERSPECTIVE_GET), EO_TYPECHECK(const Edje_Perspective **, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Group - * - * @{ - */ - -/** - * @def edje_obj_preload - * @since 1.8 - * - * @brief Preload the images on the Edje Object in the background. - * - * @param[in] cancel - * @param[out] ret - * - * @see edje_object_preload - */ -#define edje_obj_preload(cancel, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PRELOAD), EO_TYPECHECK(Eina_Bool, cancel), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_External_Group - * - * @{ - */ - -/** - * @def edje_obj_part_external_object_get - * @since 1.8 - * - * @brief Get the object created by this external part. - * - * @param[in] part - * @param[out] ret - * - * @see edje_object_part_external_object_get - */ -#define edje_obj_part_external_object_get(part, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_EXTERNAL_OBJECT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Evas_Object **, ret) - -/** - * @def edje_obj_part_external_param_set - * @since 1.8 - * - * @brief Set the parameter for the external part. - * - * @param[in] part - * @param[in] param - * @param[out] ret - * - * @see edje_object_part_external_param_set - */ -#define edje_obj_part_external_param_set(part, param, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_EXTERNAL_PARAM_SET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const Edje_External_Param *, param), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_external_param_get - * @since 1.8 - * - * @brief Get the parameter for the external part. - * - * @param[in] part - * @param[out] param - * @param[out] ret - * - * @see edje_object_part_external_param_get - */ -#define edje_obj_part_external_param_get(part, param, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_EXTERNAL_PARAM_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(Edje_External_Param *, param), EO_TYPECHECK(Eina_Bool *, ret) - -/** - * @def edje_obj_part_external_content_get - * @since 1.8 - * - * @brief Get an object contained in an part of type EXTERNAL - * - * @param[in] part - * @param[out] content - * @param[out] ret - * - * @see edje_object_part_external_content_get - */ -#define edje_obj_part_external_content_get(part, content, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_EXTERNAL_CONTENT_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, content), EO_TYPECHECK(Evas_Object **, ret) - -/** - * @def edje_obj_part_external_param_type_get - * @since 1.8 - * - * Facility to query the type of the given parameter of the given part. - * - * @param[in] part - * @param[out] param - * @param[out] ret - * - * @see edje_object_part_external_param_type_get - */ -#define edje_obj_part_external_param_type_get(part, param, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_PART_EXTERNAL_PARAM_TYPE_GET), EO_TYPECHECK(const char *, part), EO_TYPECHECK(const char *, param), EO_TYPECHECK(Edje_External_Param_Type *, ret) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Communication_Interface_Message - * - * @{ - */ - -/** - * @def edje_obj_message_send - * @since 1.8 - * - * @brief Send an (Edje) message to a given Edje object - * - * @param[in] type - * @param[in] id - * @param[in] msg - * - * @see edje_object_message_send - */ -#define edje_obj_message_send(type, id, msg) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_MESSAGE_SEND), EO_TYPECHECK(Edje_Message_Type, type), EO_TYPECHECK(int, id), EO_TYPECHECK(void *, msg) - -/** - * @def edje_obj_message_handler_set - * @since 1.8 - * - * @brief Set an Edje message handler function for a given Edje object. - * - * @param[in] func - * @param[in] data - * - * @see edje_object_message_handler_set - */ -#define edje_obj_message_handler_set(func, data) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_MESSAGE_HANDLER_SET), EO_TYPECHECK(Edje_Message_Handler_Cb, func), EO_TYPECHECK(void *, data) - -/** - * @def edje_obj_message_signal_process - * @since 1.8 - * - * @brief Process an object's message queue. - * - * - * @see edje_object_message_signal_process - */ -#define edje_obj_message_signal_process() EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_MESSAGE_SIGNAL_PROCESS) - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Communication_Interface_Signal - * - * @{ - */ - -/** - * @def edje_obj_signal_callback_add - * @since 1.8 - * - * @brief Add a callback for an arriving Edje signal, emitted by - * a given Ejde object. - * - * @param[in] emission - * @param[in] source - * @param[in] func - * @param[in] data - * - * @see edje_object_signal_callback_add - */ -#define edje_obj_signal_callback_add(emission, source, func, data) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIGNAL_CALLBACK_ADD), EO_TYPECHECK(const char *, emission), EO_TYPECHECK(const char *, source), EO_TYPECHECK(Edje_Signal_Cb, func), EO_TYPECHECK(void *, data) - -/** - * @def edje_obj_signal_callback_del - * @since 1.8 - * - * @brief Remove a signal-triggered callback from an object. - * - * @param[in] emission - * @param[in] source - * @param[in] func - * @param[in] data - * @param[out] ret - * - * @see edje_object_signal_callback_del - */ -#define edje_obj_signal_callback_del(emission, source, func, data, ret) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIGNAL_CALLBACK_DEL), EO_TYPECHECK(const char *, emission), EO_TYPECHECK(const char *, source), EO_TYPECHECK(Edje_Signal_Cb, func), EO_TYPECHECK(void *, data), EO_TYPECHECK(void **, ret) - -/** - * @def edje_obj_signal_emit - * @since 1.8 - * - * @brief Send/emit an Edje signal to a given Edje object - * - * @param[in] emission - * @param[in] source - * - * @see edje_object_signal_emit - */ -#define edje_obj_signal_emit(emission, source) EDJE_OBJ_ID(EDJE_OBJ_SUB_ID_SIGNAL_EMIT), EO_TYPECHECK(const char *, emission), EO_TYPECHECK(const char *, source) - -#endif -/** - * @} - */ -#include "edje_edit.eo.h" -#if 0 - -#define EDJE_EDIT_CLASS edje_edit_class_get() - -const Eo_Class *edje_edit_class_get(void) EINA_CONST; - -#endif \ No newline at end of file +#include "edje_edit.eo.h" \ No newline at end of file diff --git a/src/lib/edje/Edje_Legacy.h b/src/lib/edje/Edje_Legacy.h index f804cc4..e3327ad 100644 --- a/src/lib/edje/Edje_Legacy.h +++ b/src/lib/edje/Edje_Legacy.h @@ -1,2388 +1,4 @@ /** - * @defgroup Edje_External_Part_Group Edje Use of External Parts - * - * @brief Functions to manipulate parts of type EXTERNAL. - * - * Edje supports parts of type EXTERNAL, which will call plugins defined by the user - * to create and manipulate the object that's allocated in that part. - * - * Parts of type external may carry extra properties that have meanings defined - * by the external plugin. For instance, it may be a string that defines a button - * label and setting this property will change that label on the fly. - * - * @ingroup Edje_External_Group - * - * @{ - */ - -/** - * @brief Get the object created by this external part. - * - * Parts of type external creates the part object using information - * provided by external plugins. It's somehow like "swallow" - * (edje_object_part_swallow()), but it's all set automatically. - * - * This function returns the part created by such external plugins and - * being currently managed by this Edje. - * - * @note Almost all swallow rules apply: you should not move, resize, - * hide, show, set the color or clipper of such part. It's a bit - * more restrictive as one must @b never delete this object! - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return The externally created object, or NULL if there is none or - * part is not an external. - */ -EAPI Evas_Object *edje_object_part_external_object_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set the parameter for the external part. - * - * Parts of type external may carry extra properties that have - * meanings defined by the external plugin. For instance, it may be a - * string that defines a button label and setting this property will - * change that label on the fly. - * - * @note external parts have parameters set when they change - * states. Those parameters will never be changed by this - * function. The interpretation of how state_set parameters and - * param_set will interact is up to the external plugin. - * - * @note this function will not check if parameter value is valid - * using #Edje_External_Param_Info minimum, maximum, valid - * choices and others. However these should be checked by the - * underlying implementation provided by the external - * plugin. This is done for performance reasons. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param param the parameter details, including its name, type and - * actual value. This pointer should be valid, and the - * parameter must exist in - * #Edje_External_Type::parameters_info, with the exact type, - * otherwise the operation will fail and @c EINA_FALSE will be - * returned. - * - * @return @c EINA_TRUE if everything went fine, @c EINA_FALSE on errors. - */ -EAPI Eina_Bool edje_object_part_external_param_set (Evas_Object *obj, const char *part, const Edje_External_Param *param); - -/** - * @brief Get the parameter for the external part. - * - * Parts of type external may carry extra properties that have - * meanings defined by the external plugin. For instance, it may be a - * string that defines a button label. This property can be modified by - * state parameters, by explicit calls to - * edje_object_part_external_param_set() or getting the actual object - * with edje_object_part_external_object_get() and calling native - * functions. - * - * This function asks the external plugin what is the current value, - * independent on how it was set. - * - * @param obj A valid Evas_Object handle - * @param part The part name - - * @param param the parameter details. It is used as both input and - * output variable. This pointer should be valid, and the - * parameter must exist in - * #Edje_External_Type::parameters_info, with the exact type, - * otherwise the operation will fail and @c EINA_FALSE will be - * returned. - * - * @return @c EINA_TRUE if everything went fine and @p param members - * are filled with information, @c EINA_FALSE on errors and @p - * param member values are not set or valid. - */ -EAPI Eina_Bool edje_object_part_external_param_get (const Evas_Object *obj, const char *part, Edje_External_Param *param); - -/** - * @brief Get an object contained in an part of type EXTERNAL - * - * The @p content string must not be NULL. Its actual value depends on the - * code providing the EXTERNAL. - * - * @param obj The Edje object - * @param part The name of the part holding the EXTERNAL - * @param content A string identifying which content from the EXTERNAL to get - */ -EAPI Evas_Object *edje_object_part_external_content_get (const Evas_Object *obj, const char *part, const char *content); - -/** - * Facility to query the type of the given parameter of the given part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param param the parameter name to use. - * - * @return @c EDJE_EXTERNAL_PARAM_TYPE_MAX on errors, or another value - * from #Edje_External_Param_Type on success. - */ -EAPI Edje_External_Param_Type edje_object_part_external_param_type_get (const Evas_Object *obj, const char *part, const char *param); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Geometry_Group - * - * @{ - */ - -/** - * @brief Get the minimum size specified -- as an EDC property -- for a - * given Edje object - * - * @param obj A handle to an Edje object - * @param minw Pointer to a variable where to store the minimum width - * @param minh Pointer to a variable where to store the minimum height - * - * This function retrieves the @p obj object's minimum size values, - * as declared in its EDC group definition. Minimum size of - * groups have the following syntax - * @code - * collections { - * group { - * name: "a_group"; - * min: 100 100; - * } - * } - * @endcode - * - * where one declares a minimum size of 100 pixels both for width and - * height. Those are (hint) values which should be respected when the - * given object/group is to be controlled by a given container object - * (e.g. an Edje object being "swallowed" into a given @c SWALLOW - * typed part, as in edje_object_part_swallow()). Check the complete - * @ref edcref "syntax reference" for EDC files. - * - * @note If the @c min EDC property was not declared for @p obj, this - * call will return the value 0, for each axis. - * - * @note On failure, this function will make all non-@c NULL size - * pointers' pointed variables be set to zero. - * - * @see edje_object_size_max_get() - */ -EAPI void edje_object_size_min_get (const Evas_Object *obj, Evas_Coord *minw, Evas_Coord *minh); - -/** - * @brief Edje will automatically update the size hints on itself. - * - * @param obj A handle to an Edje object. - * @param update Whether or not update the size hints. - * - * By default edje doesn't set size hints on itself. With this function - * call, it will do so if update is true. Be carefully, it cost a lot to - * trigger this feature as it will recalc the object every time it make - * sense to be sure that's its minimal size hint is always accurate. - */ -EAPI void edje_object_update_hints_set(Evas_Object *obj, Eina_Bool update); - -/** - * @brief Whether or not Edje will update size hints on itself. - * - * @param obj A handle to an Edje object. - * @return @c true if does, @c false if it doesn't. - */ -EAPI Eina_Bool edje_object_update_hints_get(const Evas_Object *obj); - -/** - * @brief Get the maximum size specified -- as an EDC property -- for a - * given Edje object - * - * @param obj A handle to an Edje object - * @param maxw Pointer to a variable where to store the maximum width - * @param maxh Pointer to a variable where to store the maximum height - * - * This function retrieves the @p obj object's maximum size values, - * as declared in its EDC group definition. Maximum size of - * groups have the following syntax - * @code - * collections { - * group { - * name: "a_group"; - * max: 100 100; - * } - * } - * @endcode - * - * where one declares a maximum size of 100 pixels both for width and - * height. Those are (hint) values which should be respected when the - * given object/group is to be controlled by a given container object - * (e.g. an Edje object being "swallowed" into a given @c SWALLOW - * typed part, as in edje_object_part_swallow()). Check the complete - * @ref edcref "syntax reference" for EDC files. - * - * @note If the @c max EDC property was not declared for @p obj, this - * call will return the maximum size a given Edje object may have, for - * each axis. - * - * @note On failure, this function will make all non-@c NULL size - * pointers' pointed variables be set to zero. - * - * @see edje_object_size_min_get() - */ -EAPI void edje_object_size_max_get (const Evas_Object *obj, Evas_Coord *maxw, Evas_Coord *maxh); - -/** - * @brief Force a Size/Geometry calculation. - * - * @param obj A valid Evas_Object handle - * - * Forces the object @p obj to recalculation layout regardless of - * freeze/thaw. - */ -EAPI void edje_object_calc_force (Evas_Object *obj); - -/** - * @brief Calculate the minimum required size for a given Edje object. - * - * @param obj A handle to an Edje object - * @param minw Pointer to a variable where to store the minimum - * required width - * @param minh Pointer to a variable where to store the minimum - * required height - * - * This call works exactly as edje_object_size_min_restricted_calc(), - * with the last two arguments set to 0. Please refer to its - * documentation, then. - */ -EAPI void edje_object_size_min_calc (Evas_Object *obj, Evas_Coord *minw, Evas_Coord *minh); - -/** - * Calculate the geometry of the region, relative to a given Edje - * object's area, occupied by all parts in the object - * - * @param obj A handle to an Edje object - * @param x A pointer to a variable where to store the parts region's - * x coordinate - * @param y A pointer to a variable where to store the parts region's - * y coordinate - * @param w A pointer to a variable where to store the parts region's - * width - * @param h A pointer to a variable where to store the parts region's - * height - * - * This function gets the geometry of the rectangle equal to the area - * required to group all parts in @p obj's group/collection. The @p x - * and @p y coordinates are relative to the top left corner of the - * whole @p obj object's area. Parts placed out of the group's - * boundaries will also be taken in account, so that @p x and @p y - * may be negative. - * - * @note Use @c NULL pointers on the geometry components you're not - * interested in: they'll be ignored by the function. - * - * @note On failure, this function will make all non-@c NULL geometry - * pointers' pointed variables be set to zero. - */ -EAPI Eina_Bool edje_object_parts_extends_calc (Evas_Object *obj, Evas_Coord *x, Evas_Coord *y, Evas_Coord *w, Evas_Coord *h); - -/** - * @brief Calculate the minimum required size for a given Edje object. - * - * @param obj A handle to an Edje object - * @param minw Pointer to a variable where to store the minimum - * required width - * @param minh Pointer to a variable where to store the minimum - * required height - * @param restrictedw Do not allow object's calculated (minimum) width - * to be less than this value - * @param restrictedh Do not allow object's calculated (minimum) - * height to be less than this value - * - * This call will trigger an internal recalculation of all parts of - * the @p obj object, in order to return its minimum required - * dimensions for width and height. The user might choose to @b impose - * those minimum sizes, making the resulting calculation to get to values - * equal or bigger than @p restrictedw and @p restrictedh, for width and - * height, respectively. - * - * @note At the end of this call, @p obj @b won't be automatically - * resized to new dimensions, but just return the calculated - * sizes. The caller is the one up to change its geometry or not. - * - * @warning Be advised that invisible parts in @p obj @b will be taken - * into account in this calculation. - */ -EAPI void edje_object_size_min_restricted_calc(Evas_Object *obj, Evas_Coord *minw, Evas_Coord *minh, Evas_Coord restrictedw, Evas_Coord restrictedh); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Scale - * - * @{ - */ - -/** - * @brief Set the scaling factor for a given Edje object. - * - * @param obj A handle to an Edje object - * @param scale The scaling factor (the default value is @c 0.0, - * meaning individual scaling @b not set) - * - * This function sets an @b individual scaling factor on the @a obj - * Edje object. This property (or Edje's global scaling factor, when - * applicable), will affect this object's part sizes. If @p scale is - * not zero, than the individual scaling will @b override any global - * scaling set, for the object @p obj's parts. Put it back to zero to - * get the effects of the global scaling again. - * - * @warning Only parts which, at EDC level, had the @c "scale" - * property set to @c 1, will be affected by this function. Check the - * complete @ref edcref "syntax reference" for EDC files. - * - * @see edje_object_scale_get() - * @see edje_scale_get() for more details - */ -EAPI Eina_Bool edje_object_scale_set (Evas_Object *obj, double scale); - -/** - * @brief Get a given Edje object's scaling factor. - * - * @param obj A handle to an Edje object - * - * This function returns the @c individual scaling factor set on the - * @a obj Edje object. - * - * @see edje_object_scale_set() for more details - * - */ -EAPI double edje_object_scale_get (const Evas_Object *obj); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Part - * - * @{ - */ - -/** - * @brief Check if an Edje part exists in a given Edje object's group - * definition. - * - * @param obj A handle to an Edje object - * @param part The part's name to check for existence in @p obj's - * group - * @return @c EINA_TRUE, if the Edje part exists in @p obj's group or - * @c EINA_FALSE, otherwise (and on errors) - * - * This function returns if a given part exists in the Edje group - * bound to object @p obj (with edje_object_file_set()). - * - * This call is useful, for example, when one could expect or not a - * given GUI element, depending on the @b theme applied to @p obj. - */ -EAPI Eina_Bool edje_object_part_exists (const Evas_Object *obj, const char *part); - -/** - * @brief Get a handle to the Evas object implementing a given Edje - * part, in an Edje object. - * - * @param obj A handle to an Edje object - * @param part The Edje part's name - * @return A pointer to the Evas object implementing the given part, - * or @c NULL on failure (e.g. the given part doesn't exist) - * - * This function gets a pointer of the Evas object corresponding to a - * given part in the @p obj object's group. - * - * You should @b never modify the state of the returned object (with - * @c evas_object_move() or @c evas_object_hide() for example), - * because it's meant to be managed by Edje, solely. You are safe to - * query information about its current state (with @c - * evas_object_visible_get() or @c evas_object_color_get() for - * example), though. - */ -EAPI const Evas_Object *edje_object_part_object_get (const Evas_Object *obj, const char *part); - -/** - * @brief Retrieve the geometry of a given Edje part, in a given Edje - * object's group definition, relative to the object's area - * - * @param obj A handle to an Edje object - * @param part The Edje part's name - * @param x A pointer to a variable where to store the part's x - * coordinate - * @param y A pointer to a variable where to store the part's y - * coordinate - * @param w A pointer to a variable where to store the part's width - * @param h A pointer to a variable where to store the part's height - * - * This function gets the geometry of an Edje part within its - * group. The @p x and @p y coordinates are relative to the top left - * corner of the whole @p obj object's area. - * - * @note Use @c NULL pointers on the geometry components you're not - * interested in: they'll be ignored by the function. - * - * @note On failure, this function will make all non-@c NULL geometry - * pointers' pointed variables be set to zero. - */ -EAPI Eina_Bool edje_object_part_geometry_get (const Evas_Object *obj, const char *part, Evas_Coord *x, Evas_Coord *y, Evas_Coord *w, Evas_Coord *h); - -/** - * @brief Retrieve a list all accessibility part names - * - * @param obj A valid Evas_Object handle - * @return A list all accessibility part names on @p obj - * @since 1.7.0 - */ -EAPI Eina_List *edje_object_access_part_list_get (const Evas_Object *obj); - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Text - * - * @{ - */ - -/** - * @brief Set the object text callback. - * - * @param obj A valid Evas_Object handle - * @param func The callback function to handle the text change - * @param data The data associated to the callback function. - * - * This function sets the callback to be called when the text changes. - */ -EAPI void edje_object_text_change_cb_set (Evas_Object *obj, Edje_Text_Change_Cb func, void *data); - -/** - * @brief Sets the text for an object part - * - * @param obj A valid Evas Object handle - * @param part The part name - * @param text The text string - * - * @return @c EINA_TRUE on success, @c EINA_FALSE otherwise - */ -EAPI Eina_Bool edje_object_part_text_set (Evas_Object *obj, const char *part, const char *text); - -/** - * @brief Sets the text for an object part, but converts HTML escapes to UTF8 - * - * This converts the given string @p text to UTF8 assuming it contains HTML - * style escapes like "&" and "©" etc. IF the part is of type TEXT, - * as opposed to TEXTBLOCK. - * - * @param obj A valid Evas Object handle - * @param part The part name - * @param text The text string - * - * @return @c EINA_TRUE on success, @c EINA_FALSE otherwise - * - * @since 1.2 - */ -EAPI Eina_Bool edje_object_part_text_escaped_set (Evas_Object *obj, const char *part, const char *text); - -/** - * @brief Return the text of the object part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return The text string - * - * This function returns the text associated to the object part. - * - * @see edje_object_part_text_set(). - */ -EAPI const char *edje_object_part_text_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set the style of the - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param style The style to set (textblock conventions). - * - * This function sets the style associated with the textblock part. - * - * @since 1.2.0 - */ -EAPI void edje_object_part_text_style_user_push(Evas_Object *obj, const char *part, const char *style); - -/** - * @brief Return the text of the object part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return The text string - * - * This function returns the style associated with the textblock part. - * - * @since 1.2.0 - */ -EAPI const char *edje_object_part_text_style_user_peek(const Evas_Object *obj, const char *part); - -/** - * @brief Delete the top style form the user style stack. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @since 1.2.0 - */ -EAPI void edje_object_part_text_style_user_pop(Evas_Object *obj, const char *part); - -/** - * @brief Sets the raw (non escaped) text for an object part. - * - * @param obj A valid Evas Object handle - * @param part The part name - * @param text_to_escape The text string - * - * This funciton will not do escape for you if it is a TEXTBLOCK part, that is, - * if text contain tags, these tags will not be interpreted/parsed by TEXTBLOCK. - * - * @see edje_object_part_text_unescaped_get(). - */ -EAPI Eina_Bool edje_object_part_text_unescaped_set (Evas_Object *obj, const char *part, const char *text_to_escape); - -/** - * @brief Returns the text of the object part, without escaping. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return The @b allocated text string without escaping, or NULL on - * problems. - * - * This function is the counterpart of - * edje_object_part_text_unescaped_set(). Please notice that the - * result is newly allocated memory and should be released with free() - * when done. - * - * @see edje_object_part_text_unescaped_set(). - */ -EAPI char *edje_object_part_text_unescaped_get (const Evas_Object *obj, const char *part); - -/** - * @brief Insert text for an object part. - * - * @param obj A valid Evas Object handle - * @param part The part name - * @param text The text string - * - * This function inserts the text for an object part just before the - * cursor position. - * - */ -EAPI void edje_object_part_text_insert (Evas_Object *obj, const char *part, const char *text); - -/** - * @brief Insert text for an object part. - * - * @param obj A valid Evas Object handle - * @param part The part name - * @param text The text string - * - * This function inserts the text for an object part at the end; It does not - * move the cursor. - * - * @since 1.1 - */ -EAPI void edje_object_part_text_append(Evas_Object *obj, const char *part, const char *text); - -/** - * @brief Return a list of char anchor names. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return The list of anchors (const char *), do not modify! - * - * This function returns a list of char anchor names. - * - */ -EAPI const Eina_List *edje_object_part_text_anchor_list_get (const Evas_Object *obj, const char *part); - -/** - * @brief Return a list of Evas_Textblock_Rectangle anchor rectangles. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param anchor The anchor name - * - * @return The list of anchor rects (const Evas_Textblock_Rectangle - * *), do not modify! Geometry is relative to entry part. - * - * This function return a list of Evas_Textblock_Rectangle anchor - * rectangles. - * - */ -EAPI const Eina_List *edje_object_part_text_anchor_geometry_get (const Evas_Object *obj, const char *part, const char *anchor); - -/** - * @brief Return a list of char item names. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return The list of items (const char *), do not modify! - * - * This function returns a list of char item names. - * - */ -EAPI const Eina_List *edje_object_part_text_item_list_get (const Evas_Object *obj, const char *part); - -/** - * @brief Return item geometry. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param item The item name - * @param cx Item x return (relative to entry part) - * @param cy Item y return (relative to entry part) - * @param cw Item width return - * @param ch Item height return - * - * @return 1 if item exists, 0 if not - * - * This function return a list of Evas_Textblock_Rectangle item - * rectangles. - * - */ -EAPI Eina_Bool edje_object_part_text_item_geometry_get (const Evas_Object *obj, const char *part, const char *item, Evas_Coord *cx, Evas_Coord *cy, Evas_Coord *cw, Evas_Coord *ch); - -/** - * @brief This function inserts text as if the user has inserted it. - * - * This means it actually registers as a change and emits signals, triggers - * callbacks as appropriate. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param text The text string - * @since 1.2.0 - */ -EAPI void edje_object_part_text_user_insert (const Evas_Object *obj, const char *part, const char *text); - -/** - * @} - */ - -/** - * @ingroup Edje_Text_Selection - * - * @{ - */ - -/** - * @brief Return the selection text of the object part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return The text string - * - * This function returns selection text of the object part. - * - * @see edje_object_part_text_select_all() - * @see edje_object_part_text_select_none() - */ -EAPI const char *edje_object_part_text_selection_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set the selection to be none. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * This function sets the selection text to be none. - */ -EAPI void edje_object_part_text_select_none (const Evas_Object *obj, const char *part); - -/** - * @brief Set the selection to be everything. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * This function selects all text of the object of the part. - */ -EAPI void edje_object_part_text_select_all (const Evas_Object *obj, const char *part); - -/** - * @brief Enables selection if the entry is an EXPLICIT selection mode - * type. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param allow EINA_TRUE to enable, EINA_FALSE otherwise - * - * The default is to @b not allow selection. This function only affects user - * selection, functions such as edje_object_part_text_select_all() and - * edje_object_part_text_select_none() are not affected. - */ -EAPI void edje_object_part_text_select_allow_set (const Evas_Object *obj, const char *part, Eina_Bool allow); - -/** - * @brief Aborts any selection action on a part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - */ -EAPI void edje_object_part_text_select_abort (const Evas_Object *obj, const char *part); - -/** - * @brief Starts selecting at current cursor position - * - * @param obj A valid Evas_Object handle - * @param part The part name - */ -EAPI void edje_object_part_text_select_begin (const Evas_Object *obj, const char *part); - -/** - * @brief Extends the current selection to the current cursor position - * - * @param obj A valid Evas_Object handle - * @param part The part name - */ -EAPI void edje_object_part_text_select_extend (const Evas_Object *obj, const char *part); - -/** - * @} - */ - -/** - * @ingroup Edje_Text_Cursor - * - * @{ - */ - -/** - * @brief Advances the cursor to the next cursor position. - * @see evas_textblock_cursor_char_next - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur The edje cursor to advance - */ -EAPI Eina_Bool edje_object_part_text_cursor_next (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Moves the cursor to the previous char - * @see evas_textblock_cursor_char_prev - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI Eina_Bool edje_object_part_text_cursor_prev (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Move the cursor to the char above the current cursor position. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI Eina_Bool edje_object_part_text_cursor_up (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Moves the cursor to the char below the current cursor position. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI Eina_Bool edje_object_part_text_cursor_down (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Moves the cursor to the beginning of the text part - * @see evas_textblock_cursor_paragraph_first - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI void edje_object_part_text_cursor_begin_set (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Moves the cursor to the end of the text part. - * @see evas_textblock_cursor_paragraph_last - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI void edje_object_part_text_cursor_end_set (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Copy the cursor to another cursor. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param src the cursor to copy from - * @param dst the cursor to copy to - */ -EAPI void edje_object_part_text_cursor_copy (Evas_Object *obj, const char *part, Edje_Cursor src, Edje_Cursor dst); - -/** - * @brief Move the cursor to the beginning of the line. - * @see evas_textblock_cursor_line_char_first - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI void edje_object_part_text_cursor_line_begin_set (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Move the cursor to the end of the line. - * @see evas_textblock_cursor_line_char_last - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur the edje cursor to work on - */ -EAPI void edje_object_part_text_cursor_line_end_set (Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * Position the given cursor to a X,Y position. - * - * This is frequently used with the user cursor. - * - * @param obj An Edje object. - * @param part The part containing the object. - * @param cur The cursor to adjust. - * @param x X Coordinate. - * @param y Y Coordinate. - * @return True on success, false on error. - */ -EAPI Eina_Bool edje_object_part_text_cursor_coord_set (Evas_Object *obj, const char *part, Edje_Cursor cur, Evas_Coord x, Evas_Coord y); - -/** - * @brief Returns whether the cursor points to a format. - * @see evas_textblock_cursor_is_format - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur The cursor to adjust. - * @return EINA_TRUE if it's true, EINA_FALSE otherwise. - */ -EAPI Eina_Bool edje_object_part_text_cursor_is_format_get (const Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Return true if the cursor points to a visible format - * For example \\t, \\n, item and etc. - * @see evas_textblock_cursor_format_is_visible_get - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur The cursor to adjust. - */ -EAPI Eina_Bool edje_object_part_text_cursor_is_visible_format_get(const Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Returns the content (char) at the cursor position. - * @see evas_textblock_cursor_content_get - * - * You must free the return (if not NULL) after you are done with it. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur The cursor to use - * @return The character string pointed to (may be a multi-byte utf8 sequence) terminated by a nul byte. - */ -EAPI char *edje_object_part_text_cursor_content_get (const Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Sets the cursor position to the given value - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur The cursor to move - * @param pos the position of the cursor - * @since 1.1.0 - */ -EAPI void edje_object_part_text_cursor_pos_set (Evas_Object *obj, const char *part, Edje_Cursor cur, int pos); - -/** - * @brief Retrieves the current position of the cursor - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cur The cursor to get the position - * @return The cursor position - * @since 1.1.0 - */ -EAPI int edje_object_part_text_cursor_pos_get (const Evas_Object *obj, const char *part, Edje_Cursor cur); - -/** - * @brief Returns the cursor geometry of the part relative to the edje - * object. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param x Cursor X position - * @param y Cursor Y position - * @param w Cursor width - * @param h Cursor height - * - */ -EAPI void edje_object_part_text_cursor_geometry_get (const Evas_Object *obj, const char *part, Evas_Coord *x, Evas_Coord *y, Evas_Coord *w, Evas_Coord *h); - -/** - * @} - */ - -/** - * @ingroup Edje_Text_Entry - * - * @{ - */ - -/** - * @brief Set the RTL orientation for this object. - * - * @param obj A handle to an Edje object. - * @param rtl new value of flag EINA_TRUE/EINA_FALSE - * @since 1.1.0 - */ -EAPI void edje_object_mirrored_set (Evas_Object *obj, Eina_Bool rtl); - -/** - * @brief Get the RTL orientation for this object. - * - * You can RTL orientation explicitly with edje_object_mirrored_set. - * - * @param obj A handle to an Edje object. - * @return @c EINA_TRUE if the flag is set or @c EINA_FALSE if not. - * @since 1.1.0 - */ -EAPI Eina_Bool edje_object_mirrored_get (const Evas_Object *obj); - -/** - * @brief Set the function that provides item objects for named items in an edje entry text - * - * @param obj A valid Evas Object handle - * @param func The function to call (or NULL to disable) to get item objects - * @param data The data pointer to pass to the @p func callback - * - * Item objects may be deleted any time by Edje, and will be deleted when the - * Edje object is deleted (or file is set to a new file). - */ -EAPI void edje_object_item_provider_set (Evas_Object *obj, Edje_Item_Provider_Cb func, void *data); - -/** - * @brief Reset the input method context if needed. - * - * This can be necessary in the case where modifying the buffer would confuse on-going input method behavior - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @since 1.2.0 - */ -EAPI void edje_object_part_text_imf_context_reset (const Evas_Object *obj, const char *part); - -/** - * @brief Get the input method context in entry. - * - * If ecore_imf was not available when edje was compiled, this function returns NULL - * otherwise, the returned pointer is an Ecore_IMF * - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return The input method context (Ecore_IMF_Context *) in entry - * @since 1.2.0 - */ -EAPI void *edje_object_part_text_imf_context_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set the layout of the input panel. - * - * The layout of the input panel or virtual keyboard can make it easier or - * harder to enter content. This allows you to hint what kind of input you - * are expecting to enter and thus have the input panel automatically - * come up with the right mode. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param layout layout type - * @since 1.1 - */ -EAPI void edje_object_part_text_input_panel_layout_set (Evas_Object *obj, const char *part, Edje_Input_Panel_Layout layout); - -/** - * @brief Get the layout of the input panel. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return Layout type of the input panel - * - * @see edje_object_part_text_input_panel_layout_set - * @since 1.1 - */ -EAPI Edje_Input_Panel_Layout edje_object_part_text_input_panel_layout_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set the layout variation of the input panel. - * - * The layout variation of the input panel or virtual keyboard can make it easier or - * harder to enter content. This allows you to hint what kind of input you - * are expecting to enter and thus have the input panel automatically - * come up with the right mode. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param variation layout variation type - * @since 1.8 - */ -EAPI void edje_object_part_text_input_panel_layout_variation_set(Evas_Object *obj, const char *part, int variation); - -/** - * @brief Get the layout variation of the input panel. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * @return Layout variation type of the input panel - * - * @see edje_object_part_text_input_panel_layout_variation_set - * @since 1.8 - */ -EAPI int edje_object_part_text_input_panel_layout_variation_get(const Evas_Object *obj, const char *part); - -/** - * @brief Set the autocapitalization type on the immodule. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param autocapital_type The type of autocapitalization - * @since 1.1.0 - */ -EAPI void edje_object_part_text_autocapital_type_set (Evas_Object *obj, const char *part, Edje_Text_Autocapital_Type autocapital_type); - -/** - * @brief Retrieves the autocapitalization type - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return The autocapitalization type - * @since 1.1.0 - */ -EAPI Edje_Text_Autocapital_Type edje_object_part_text_autocapital_type_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set whether the prediction is allowed or not. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param prediction If true, the prediction feature is allowed. - * @since 1.2.0 - */ -EAPI void edje_object_part_text_prediction_allow_set (Evas_Object *obj, const char *part, Eina_Bool prediction); - -/** - * @brief Get whether the prediction is allowed or not. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return EINA_TRUE if prediction feature is allowed. - * @since 1.2.0 - */ -EAPI Eina_Bool edje_object_part_text_prediction_allow_get (const Evas_Object *obj, const char *part); - -/** - * @brief Sets the attribute to show the input panel automatically. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param enabled If true, the input panel is appeared when entry is clicked or has a focus - * @since 1.1.0 - */ -EAPI void edje_object_part_text_input_panel_enabled_set (Evas_Object *obj, const char *part, Eina_Bool enabled); - -/** - * @brief Retrieve the attribute to show the input panel automatically. - * @see edje_object_part_text_input_panel_enabled_set - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return EINA_TRUE if it supports or EINA_FALSE otherwise - * @since 1.1.0 - */ -EAPI Eina_Bool edje_object_part_text_input_panel_enabled_get (const Evas_Object *obj, const char *part); - -/** - * @brief Show the input panel (virtual keyboard) based on the input panel property such as layout, autocapital types, and so on. - * - * Note that input panel is shown or hidden automatically according to the focus state. - * This API can be used in the case of manually controlling by using edje_object_part_text_input_panel_enabled_set. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_show(const Evas_Object *obj, const char *part); - -/** - * @brief Hide the input panel (virtual keyboard). - * @see edje_object_part_text_input_panel_show - * - * Note that input panel is shown or hidden automatically according to the focus state. - * This API can be used in the case of manually controlling by using edje_object_part_text_input_panel_enabled_set. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_hide(const Evas_Object *obj, const char *part); - -/** - * Set the language mode of the input panel. - * - * This API can be used if you want to show the Alphabet keyboard. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param lang the language to be set to the input panel. - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_language_set(Evas_Object *obj, const char *part, Edje_Input_Panel_Lang lang); - -/** - * Get the language mode of the input panel. - * - * See @ref edje_object_part_text_input_panel_language_set for more details. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return input panel language type - * @since 1.2.0 - */ -EAPI Edje_Input_Panel_Lang edje_object_part_text_input_panel_language_get(const Evas_Object *obj, const char *part); - -/** - * Set the input panel-specific data to deliver to the input panel. - * - * This API is used by applications to deliver specific data to the input panel. - * The data format MUST be negotiated by both application and the input panel. - * The size and format of data are defined by the input panel. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param data The specific data to be set to the input panel. - * @param len the length of data, in bytes, to send to the input panel - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_imdata_set(Evas_Object *obj, const char *part, const void *data, int len); - -/** - * Get the specific data of the current active input panel. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param data The specific data to be got from the input panel - * @param len The length of data - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_imdata_get(const Evas_Object *obj, const char *part, void *data, int *len); - -/** - * Set the "return" key type. This type is used to set string or icon on the "return" key of the input panel. - * - * An input panel displays the string or icon associated with this type - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param return_key_type The type of "return" key on the input panel - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_return_key_type_set(Evas_Object *obj, const char *part, Edje_Input_Panel_Return_Key_Type return_key_type); - -/** - * Get the "return" key type. - * - * @see edje_object_part_text_input_panel_return_key_type_set() for more details - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return The type of "return" key on the input panel - * @since 1.2.0 - */ -EAPI Edje_Input_Panel_Return_Key_Type edje_object_part_text_input_panel_return_key_type_get(const Evas_Object *obj, const char *part); - -/** - * Set the return key on the input panel to be disabled. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param disabled The state - * @since 1.2.0 - */ -EAPI void edje_object_part_text_input_panel_return_key_disabled_set(Evas_Object *obj, const char *part, Eina_Bool disabled); - -/** - * Get whether the return key on the input panel should be disabled or not. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return EINA_TRUE if it should be disabled - * @since 1.2.0 - */ -EAPI Eina_Bool edje_object_part_text_input_panel_return_key_disabled_get(const Evas_Object *obj, const char *part); - -/** - * Set the attribute to show the input panel in case of only an user's explicit Mouse Up event. - * It doesn't request to show the input panel even though it has focus. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param ondemand If true, the input panel will be shown in case of only Mouse up event. (Focus event will be ignored.) - * @since 1.9.0 - */ -EAPI void edje_object_part_text_input_panel_show_on_demand_set(Evas_Object *obj, const char *part, Eina_Bool ondemand); - -/** - * Get the attribute to show the input panel in case of only an user's explicit Mouse Up event. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return @c EINA_TRUE if the input panel will be shown in case of only Mouse up event. - * @since 1.9.0 - */ -EAPI Eina_Bool edje_object_part_text_input_panel_show_on_demand_get(const Evas_Object *obj, const char *part); - -/** - * Add a filter function for newly inserted text. - * - * Whenever text is inserted (not the same as set) into the given @p part, - * the list of filter functions will be called to decide if and how the new - * text will be accepted. - * There are three types of filters, EDJE_TEXT_FILTER_TEXT, - * EDJE_TEXT_FILTER_FORMAT and EDJE_TEXT_FILTER_MARKUP. - * The text parameter in the @p func filter can be modified by the user and - * it's up to him to free the one passed if he's to change the pointer. If - * doing so, the newly set text should be malloc'ed, as once all the filters - * are called Edje will free it. - * If the text is to be rejected, freeing it and setting the pointer to NULL - * will make Edje break out of the filter cycle and reject the inserted - * text. - * - * @warning This function will be deprecated because of difficulty in use. - * The type(format, text, or markup) of text should be always - * checked in the filter function for correct filtering. - * Please use edje_object_text_markup_filter_callback_add() instead. There - * is no need to check the type of text in the filter function - * because the text is always markup. - * @warning If you use this function with - * edje_object_text_markup_filter_callback_add() together, all - * Edje_Text_Filter_Cb functions and Edje_Markup_Filter_Cb functions - * will be executed, and then filtered text will be inserted. - * - * @see edje_object_text_insert_filter_callback_del - * @see edje_object_text_insert_filter_callback_del_full - * @see edje_object_text_markup_filter_callback_add - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param func The callback function that will act as filter - * @param data User provided data to pass to the filter function - */ -EAPI void edje_object_text_insert_filter_callback_add (Evas_Object *obj, const char *part, Edje_Text_Filter_Cb func, void *data); - -/** - * Delete a function from the filter list. - * - * Delete the given @p func filter from the list in @p part. Returns - * the user data pointer given when added. - * - * @see edje_object_text_insert_filter_callback_add - * @see edje_object_text_insert_filter_callback_del_full - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param func The function callback to remove - * - * @return The user data pointer if successful, or NULL otherwise - */ -EAPI void *edje_object_text_insert_filter_callback_del (Evas_Object *obj, const char *part, Edje_Text_Filter_Cb func); - -/** - * Delete a function and matching user data from the filter list. - * - * Delete the given @p func filter and @p data user data from the list - * in @p part. - * Returns the user data pointer given when added. - * - * @see edje_object_text_insert_filter_callback_add - * @see edje_object_text_insert_filter_callback_del - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param func The function callback to remove - * @param data The data passed to the callback function - * - * @return The same data pointer if successful, or NULL otherwise - */ -EAPI void *edje_object_text_insert_filter_callback_del_full (Evas_Object *obj, const char *part, Edje_Text_Filter_Cb func, void *data); - -/** - * Add a markup filter function for newly inserted text. - * - * Whenever text is inserted (not the same as set) into the given @p part, - * the list of markup filter functions will be called to decide if and how - * the new text will be accepted. - * The text parameter in the @p func filter is always markup. It can be - * modified by the user and it's up to him to free the one passed if he's to - * change the pointer. If doing so, the newly set text should be malloc'ed, - * as once all the filters are called Edje will free it. - * If the text is to be rejected, freeing it and setting the pointer to NULL - * will make Edje break out of the filter cycle and reject the inserted - * text. - * This function is different from edje_object_text_insert_filter_callback_add() - * in that the text parameter in the @p fucn filter is always markup. - * - * @warning If you use this function with - * edje_object_text_insert_filter_callback_add() togehter, all - * Edje_Text_Filter_Cb functions and Edje_Markup_Filter_Cb functions - * will be executed, and then filtered text will be inserted. - * - * @see edje_object_text_markup_filter_callback_del - * @see edje_object_text_markup_filter_callback_del_full - * @see edje_object_text_insert_filter_callback_add - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param func The callback function that will act as markup filter - * @param data User provided data to pass to the filter function - * @since 1.2.0 - */ -EAPI void edje_object_text_markup_filter_callback_add(Evas_Object *obj, const char *part, Edje_Markup_Filter_Cb func, void *data); - -/** - * Delete a function from the markup filter list. - * - * Delete the given @p func filter from the list in @p part. Returns - * the user data pointer given when added. - * - * @see edje_object_text_markup_filter_callback_add - * @see edje_object_text_markup_filter_callback_del_full - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param func The function callback to remove - * - * @return The user data pointer if successful, or NULL otherwise - * @since 1.2.0 - */ -EAPI void *edje_object_text_markup_filter_callback_del(Evas_Object *obj, const char *part, Edje_Markup_Filter_Cb func); - -/** - * Delete a function and matching user data from the markup filter list. - * - * Delete the given @p func filter and @p data user data from the list - * in @p part. - * Returns the user data pointer given when added. - * - * @see edje_object_text_markup_filter_callback_add - * @see edje_object_text_markup_filter_callback_del - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param func The function callback to remove - * @param data The data passed to the callback function - * - * @return The same data pointer if successful, or NULL otherwise - * @since 1.2.0 - */ -EAPI void *edje_object_text_markup_filter_callback_del_full(Evas_Object *obj, const char *part, Edje_Markup_Filter_Cb func, void *data); - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Swallow - * - * @{ - */ - -/** - * @brief Set the object minimum size. - * - * @param obj A valid Evas_Object handle - * @param minw The minimum width - * @param minh The minimum height - * - * This sets the minimum size restriction for the object. - */ -EAPI void edje_extern_object_min_size_set (Evas_Object *obj, Evas_Coord minw, Evas_Coord minh); - -/** - * @brief Set the object maximum size. - * - * @param obj A valid Evas_Object handle - * @param maxw The maximum width - * @param maxh The maximum height - * - * This sets the maximum size restriction for the object. - */ -EAPI void edje_extern_object_max_size_set (Evas_Object *obj, Evas_Coord maxw, Evas_Coord maxh); - -/** - * @brief Set the object aspect size. - * - * @param obj A valid Evas_Object handle - * @param aspect The aspect control axes - * @param aw The aspect radio width - * @param ah The aspect ratio height - * - * This sets the desired aspect ratio to keep an object that will be - * swallowed by Edje. The width and height define a preferred size - * ASPECT and the object may be scaled to be larger or smaller, but - * retaining the relative scale of both aspect width and height. - */ -EAPI void edje_extern_object_aspect_set (Evas_Object *obj, Edje_Aspect_Control aspect, Evas_Coord aw, Evas_Coord ah); - -/** - * @brief "Swallows" an object into one of the Edje object @c SWALLOW - * parts. - * - * @param obj A valid Edje object handle - * @param part The swallow part's name - * @param obj_swallow The object to occupy that part - * - * Swallowing an object into an Edje object is, for a given part of - * type @c SWALLOW in the EDC group which gave life to @a obj, to set - * an external object to be controlled by @a obj, being displayed - * exactly over that part's region inside the whole Edje object's - * viewport. - * - * From this point on, @a obj will have total control over @a - * obj_swallow's geometry and visibility. For instance, if @a obj is - * visible, as in @c evas_object_show(), the swallowed object will be - * visible too -- if the given @c SWALLOW part it's in is also - * visible. Other actions on @a obj will also reflect on the swallowed - * object as well (e.g. resizing, moving, raising/lowering, etc.). - * - * Finally, all internal changes to @a part, specifically, will - * reflect on the displaying of @a obj_swallow, for example state - * changes leading to different visibility states, geometries, - * positions, etc. - * - * If an object has already been swallowed into this part, then it - * will first be unswallowed (as in edje_object_part_unswallow()) - * before the new object is swallowed. - * - * @note @a obj @b won't delete the swallowed object once it is - * deleted -- @a obj_swallow will get to an unparented state again. - * - * For more details on EDC @c SWALLOW parts, see @ref edcref "syntax - * reference". - */ -EAPI Eina_Bool edje_object_part_swallow (Evas_Object *obj, const char *part, Evas_Object *obj_swallow); - -/** - * @brief Unswallow an object. - * - * @param obj A valid Evas_Object handle - * @param obj_swallow The swallowed object - * - * Causes the edje to regurgitate a previously swallowed object. :) - * - * @note @p obj_swallow will @b not be deleted or hidden. - * @note @p obj_swallow may appear shown on the evas depending on its state when - * it got unswallowed. Make sure you delete it or hide it if you do not want it to. - */ -EAPI void edje_object_part_unswallow (Evas_Object *obj, Evas_Object *obj_swallow); - -/** - * @brief Get the object currently swallowed by a part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @return The swallowed object, or NULL if there is none. - */ -EAPI Evas_Object *edje_object_part_swallow_get (const Evas_Object *obj, const char *part); - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Drag - * - * @{ - */ - -/** - * @brief Determine dragable directions. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * - * The dragable directions are defined in the EDC file, inside the @c dragable - * section, by the attributes @c x and @c y. See the @ref edcref for more - * information. - * - * @return #EDJE_DRAG_DIR_NONE: Not dragable\n - * #EDJE_DRAG_DIR_X: Dragable in X direction\n - * #EDJE_DRAG_DIR_Y: Dragable in Y direction\n - * #EDJE_DRAG_DIR_XY: Dragable in X & Y directions - */ -EAPI Edje_Drag_Dir edje_object_part_drag_dir_get (const Evas_Object *obj, const char *part); - -/** - * @brief Set the dragable object location. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The x value - * @param dy The y value - * - * Places the dragable object at the given location. - * - * Values for @p dx and @p dy are real numbers that range from 0 to 1, - * representing the relative position to the dragable area on that axis. - * - * This value means, for the vertical axis, that 0.0 will be at the top if the - * first parameter of @c y in the dragable part theme is 1, and at bottom if it - * is -1. - * - * For the horizontal axis, 0.0 means left if the first parameter of @c x in the - * dragable part theme is 1, and right if it is -1. - * - * @see edje_object_part_drag_value_get() - */ -EAPI Eina_Bool edje_object_part_drag_value_set (Evas_Object *obj, const char *part, double dx, double dy); - -/** - * @brief Get the dragable object location. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The X value pointer - * @param dy The Y value pointer - * - * Values for @p dx and @p dy are real numbers that range from 0 to 1, - * representing the relative position to the dragable area on that axis. - * - * @see edje_object_part_drag_value_set() - * - * Gets the drag location values. - */ -EAPI Eina_Bool edje_object_part_drag_value_get (const Evas_Object *obj, const char *part, double *dx, double *dy); - -/** - * @brief Set the dragable object size. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dw The drag width - * @param dh The drag height - * - * Values for @p dw and @p dh are real numbers that range from 0 to 1, - * representing the relative size of the dragable area on that axis. - * - * Sets the size of the dragable object. - * - * @see edje_object_part_drag_size_get() - */ -EAPI Eina_Bool edje_object_part_drag_size_set (Evas_Object *obj, const char *part, double dw, double dh); - -/** - * @brief Get the dragable object size. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dw The drag width pointer - * @param dh The drag height pointer - * - * Gets the dragable object size. - * - * @see edje_object_part_drag_size_set() - */ -EAPI Eina_Bool edje_object_part_drag_size_get (const Evas_Object *obj, const char *part, double *dw, double *dh); - -/** - * @brief Sets the drag step increment. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The x step amount - * @param dy The y step amount - * - * Sets the x,y step increments for a dragable object. - * - * Values for @p dx and @p dy are real numbers that range from 0 to 1, - * representing the relative size of the dragable area on that axis by which the - * part will be moved. - * - * @see edje_object_part_drag_step_get() - */ -EAPI Eina_Bool edje_object_part_drag_step_set (Evas_Object *obj, const char *part, double dx, double dy); - -/** - * @brief Gets the drag step increment values. - * - * @param obj A valid Evas_Object handle - * @param part The part - * @param dx The x step increment pointer - * @param dy The y step increment pointer - * - * Gets the x and y step increments for the dragable object. - * - * - * @see edje_object_part_drag_step_set() - */ -EAPI Eina_Bool edje_object_part_drag_step_get (const Evas_Object *obj, const char *part, double *dx, double *dy); - -/** - * @brief Sets the page step increments. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The x page step increment - * @param dy The y page step increment - * - * Sets the x,y page step increment values. - * - * Values for @p dx and @p dy are real numbers that range from 0 to 1, - * representing the relative size of the dragable area on that axis by which the - * part will be moved. - * - * @see edje_object_part_drag_page_get() - */ -EAPI Eina_Bool edje_object_part_drag_page_set (Evas_Object *obj, const char *part, double dx, double dy); - -/** - * @brief Gets the page step increments. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The dx page increment pointer - * @param dy The dy page increment pointer - * - * Gets the x,y page step increments for the dragable object. - * - * @see edje_object_part_drag_page_set() - */ -EAPI Eina_Bool edje_object_part_drag_page_get (const Evas_Object *obj, const char *part, double *dx, double *dy); - -/** - * @brief Steps the dragable x,y steps. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The x step - * @param dy The y step - * - * Steps x,y where the step increment is the amount set by - * edje_object_part_drag_step_set. - * - * Values for @p dx and @p dy are real numbers that range from 0 to 1. - * - * @see edje_object_part_drag_page() - */ -EAPI Eina_Bool edje_object_part_drag_step (Evas_Object *obj, const char *part, double dx, double dy); - -/** - * @brief Pages x,y steps. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param dx The x step - * @param dy The y step - * - * Pages x,y where the increment is defined by - * edje_object_part_drag_page_set. - * - * Values for @p dx and @p dy are real numbers that range from 0 to 1. - * - * @warning Paging is bugged! - * - * @see edje_object_part_drag_step() - */ -EAPI Eina_Bool edje_object_part_drag_page (Evas_Object *obj, const char *part, double dx, double dy); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_File - * - * @{ - */ - -/** - * @brief Retrive an EDC data field's value from a given Edje - * object's group. - * - * @param obj A handle to an Edje object - * @param key The data field's key string - * @return The data's value string. Must not be freed. - * - * This function fetches an EDC data field's value, which is declared - * on the objects building EDC file, under its group. EDC data - * blocks are most commonly used to pass arbitrary parameters from an - * application's theme to its code. - * - * They look like the following: - * - * @code - * collections { - * group { - * name: "a_group"; - * data { - * item: "key1" "value1"; - * item: "key2" "value2"; - * } - * } - * } - * @endcode - * - * EDC data fields always hold @b strings as values, hence the return - * type of this function. Check the complete @ref edcref "syntax reference" - * for EDC files. - * - * @warning Do not confuse this call with edje_file_data_get(), which - * queries for a @b global EDC data field on an EDC declaration file. - * - * @see edje_object_file_set() - */ -EAPI const char *edje_object_data_get (const Evas_Object *obj, const char *key); - -/** - * @brief Sets the @b EDJ file (and group within it) to load an Edje - * object's contents from - * - * @param obj A handle to an Edje object - * @param file The path to the EDJ file to load @p from - * @param group The name of the group, in @p file, which implements an - * Edje object - * @return @c EINA_TRUE, on success or @c EINA_FALSE, on errors (check - * edje_object_load_error_get() after this call to get errors causes) - * - * Edje expects EDJ files, which are theming objects' descriptions and - * resources packed together in an EET file, to read Edje object - * definitions from. They usually are created with the @c .edj - * extension. EDJ files, in turn, are assembled from @b textual object - * description files, where one describes Edje objects declaratively - * -- the EDC files (see @ref edcref "the syntax" for those files). - * - * Those description files were designed so that many Edje object - * definitions -- also called @b groups (or collections) -- could be - * packed together in the same EDJ file, so that a whole - * application's theme could be packed in one file only. This is the - * reason for the @p group argument. - * - * Use this function after you instantiate a new Edje object, so that - * you can "give him life", telling where to get its contents from. - * - * @see edje_object_add() - * @see edje_object_file_get() - * @see edje_object_mmap_set() - */ -EAPI Eina_Bool edje_object_file_set (Evas_Object *obj, const char *file, const char *group); - -/** - * @brief Sets the @b EDJ file (and group within it) to load an Edje - * object's contents from - * - * @param obj A handle to an Edje object - * @param file The Eina_File pointing to the EDJ file to load @p from - * @param group The name of the group, in @p file, which implements an - * Edje object - * @return @c EINA_TRUE, on success or @c EINA_FALSE, on errors (check - * edje_object_load_error_get() after this call to get errors causes) - * - * Edje expects EDJ files, which are theming objects' descriptions and - * resources packed together in an EET file, to read Edje object - * definitions from. They usually are created with the @c .edj - * extension. EDJ files, in turn, are assembled from @b textual object - * description files, where one describes Edje objects declaratively - * -- the EDC files (see @ref edcref "the syntax" for those files). - * - * Those description files were designed so that many Edje object - * definitions -- also called @b groups (or collections) -- could be - * packed together in the same EDJ file, so that a whole - * application's theme could be packed in one file only. This is the - * reason for the @p group argument. - * - * Use this function after you instantiate a new Edje object, so that - * you can "give him life", telling where to get its contents from. - * - * @see edje_object_add() - * @see edje_object_file_get() - * @see edje_object_mmap_set() - * @since 1.8 - */ -EAPI Eina_Bool edje_object_mmap_set(Evas_Object *obj, const Eina_File *file, const char *group); - - -/** - * @brief Get the file and group name that a given Edje object is bound to - * - * @param obj A handle to an Edje object - * @param file A pointer to a variable whero to store the file's - * path - * @param group A pointer to a variable where to store the group - * name in - * - * This gets the EDJ file's path, with the respective group set for - * the given Edje object. If @a obj is either not an Edje file, or has - * not had its file/group set previously, by edje_object_file_set(), - * then both @p file and @p group will be set to @c NULL, indicating - * an error. - * - * @see edje_object_file_set() - * - * @note Use @c NULL pointers on the file/group components you're not - * interested in: they'll be ignored by the function. - */ -EAPI void edje_object_file_get (const Evas_Object *obj, const char **file, const char **group); - -/** - * @brief Gets the (last) file loading error for a given Edje object - * - * @param obj A handlet to an Edje object - * - * @return The Edje loading error, one of: - * - #EDJE_LOAD_ERROR_NONE - * - #EDJE_LOAD_ERROR_GENERIC - * - #EDJE_LOAD_ERROR_DOES_NOT_EXIST - * - #EDJE_LOAD_ERROR_PERMISSION_DENIED - * - #EDJE_LOAD_ERROR_RESOURCE_ALLOCATION_FAILED - * - #EDJE_LOAD_ERROR_CORRUPT_FILE - * - #EDJE_LOAD_ERROR_UNKNOWN_FORMAT - * - #EDJE_LOAD_ERROR_INCOMPATIBLE_FILE - * - #EDJE_LOAD_ERROR_UNKNOWN_COLLECTION - * - #EDJE_LOAD_ERROR_RECURSIVE_REFERENCE - * - * This function is meant to be used after an Edje EDJ file - * loading, what takes place with the edje_object_file_set() - * function. If that function does not return @c EINA_TRUE, one should - * check for the reason of failure with this one. - * - * @see edje_load_error_str() - */ -EAPI Edje_Load_Error edje_object_load_error_get (const Evas_Object *obj); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Animation - * - * @{ - */ - -/** - * @brief Set the Edje object to playing or paused states. - * - * @param obj A handle to an Edje object. - * @param play Object state (@c EINA_TRUE to playing, - * @c EINA_FALSE to paused). - * - * This function sets the Edje object @a obj to playing or paused - * states, depending on the parameter @a play. This has no effect if - * the object was already at that state. - * - * @see edje_object_play_get(). - * - */ -EAPI void edje_object_play_set (Evas_Object *obj, Eina_Bool play); - -/** - * @brief Get the Edje object's state. - * - * @param obj A handle to an Edje object. - * @return @c EINA_FALSE if the object is not connected, its @c delete_me flag - * is set, or it is at paused state; @c EINA_TRUE if the object is at playing - * state. - * - * This function tells if an Edje object is playing or not. This state - * is set by edje_object_play_set(). - * - * @see edje_object_play_set(). - * - */ -EAPI Eina_Bool edje_object_play_get (const Evas_Object *obj); - -/** - * @brief Set the object's animation state. - * - * @param obj A handle to an Edje object. - * @param on The animation state. @c EINA_TRUE to starts or - * @c EINA_FALSE to stops. - * - * This function starts or stops an Edje object's animation. The - * information if it's stopped can be retrieved by - * edje_object_animation_get(). - * - * @see edje_object_animation_get() - * - */ -EAPI void edje_object_animation_set (Evas_Object *obj, Eina_Bool on); - -/** - * @brief Get the Edje object's animation state. - * - * @param obj A handle to an Edje object. - * @return @c EINA_FALSE on error or if object is not animated; - * @c EINA_TRUE if animated. - * - * This function returns if the animation is stopped or not. The - * animation state is set by edje_object_animation_set(). - * - * @see edje_object_animation_set(). - * - */ -EAPI Eina_Bool edje_object_animation_get (const Evas_Object *obj); - -/** - * @brief Freezes the Edje object. - * - * @param obj A handle to an Edje object. - * @return The frozen state or 0 on Error - * - * This function puts all changes on hold. Successive freezes will - * nest, requiring an equal number of thaws. - * - * @see edje_object_thaw() - */ -EAPI int edje_object_freeze (Evas_Object *obj); - -/** - * @brief Thaws the Edje object. - * - * @param obj A handle to an Edje object. - * @return The frozen state or 0 if the object is not frozen or on error. - * - * This function thaws the given Edje object. - * - * @note: If sucessives freezes were done, an equal number of - * thaws will be required. - * - * @see edje_object_freeze() - */ -EAPI int edje_object_thaw (Evas_Object *obj); - -/** - * @brief Returns the state of the Edje part. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param val_ret - * - * @return The part state:\n - * "default" for the default state\n - * "" for other states - */ -EAPI const char *edje_object_part_state_get (const Evas_Object *obj, const char *part, double *val_ret); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Color_Class - * - * @{ - */ - -/** - * @brief Sets the object color class. - * - * @param obj A valid Evas_Object handle - * @param color_class - * @param r Object Red value - * @param g Object Green value - * @param b Object Blue value - * @param a Object Alpha value - * @param r2 Outline Red value - * @param g2 Outline Green value - * @param b2 Outline Blue value - * @param a2 Outline Alpha value - * @param r3 Shadow Red value - * @param g3 Shadow Green value - * @param b3 Shadow Blue value - * @param a3 Shadow Alpha value - * - * This function sets the color values for an object level color - * class. This will cause all edje parts in the specified object that - * have the specified color class to have their colors multiplied by - * these values. - * - * The first color is the object, the second is the text outline, and - * the third is the text shadow. (Note that the second two only apply - * to text parts). - * - * Setting color emits a signal "color_class,set" with source being - * the given color. - * - * @note unlike Evas, Edje colors are @b not pre-multiplied. That is, - * half-transparent white is 255 255 255 128. - */ -EAPI Eina_Bool edje_object_color_class_set (Evas_Object *obj, const char *color_class, int r, int g, int b, int a, int r2, int g2, int b2, int a2, int r3, int g3, int b3, int a3); - -/** - * @brief Gets the object color class. - * - * @param o A valid Evas_Object handle - * @param color_class - * @param r Object Red value - * @param g Object Green value - * @param b Object Blue value - * @param a Object Alpha value - * @param r2 Outline Red value - * @param g2 Outline Green value - * @param b2 Outline Blue value - * @param a2 Outline Alpha value - * @param r3 Shadow Red value - * @param g3 Shadow Green value - * @param b3 Shadow Blue value - * @param a3 Shadow Alpha value - * - * @return EINA_TRUE if found or EINA_FALSE if not found and all - * values are zeroed. - * - * This function gets the color values for an object level color - * class. If no explicit object color is set, then global values will - * be used. - * - * The first color is the object, the second is the text outline, and - * the third is the text shadow. (Note that the second two only apply - * to text parts). - * - * @note unlike Evas, Edje colors are @b not pre-multiplied. That is, - * half-transparent white is 255 255 255 128. - */ -EAPI Eina_Bool edje_object_color_class_get (const Evas_Object *o, const char *color_class, int *r, int *g, int *b, int *a, int *r2, int *g2, int *b2, int *a2, int *r3, int *g3, int *b3, int *a3); - -/** - * @brief Delete the object color class. - * - * @param obj The edje object's reference. - * @param color_class The color class to be deleted. - * - * This function deletes any values at the object level for the - * specified object and color class. - * @note Deleting the color class will revert it to the values - * defined by edje_color_class_set() or the color class - * defined in the theme file. - * - * Deleting the color class will emit the signal "color_class,del" - * for the given Edje object. - */ - EAPI void edje_object_color_class_del (Evas_Object *obj, const char *color_class); - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Box - * - * @{ - */ - -/** - * @brief Appends an object to the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child The object to append - * - * @return @c EINA_TRUE: Successfully added.\n - * @c EINA_FALSE: An error occurred. - * - * Appends child to the box indicated by part. - * - * @see edje_object_part_box_prepend() - * @see edje_object_part_box_insert_before() - * @see edje_object_part_box_insert_at() - */ -EAPI Eina_Bool edje_object_part_box_append (Evas_Object *obj, const char *part, Evas_Object *child); - -/** - * @brief Prepends an object to the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child The object to prepend - * - * @return @c EINA_TRUE: Successfully added.\n - * @c EINA_FALSE: An error occurred. - * - * Prepends child to the box indicated by part. - * - * @see edje_object_part_box_append() - * @see edje_object_part_box_insert_before() - * @see edje_object_part_box_insert_at() - */ -EAPI Eina_Bool edje_object_part_box_prepend (Evas_Object *obj, const char *part, Evas_Object *child); - -/** - * @brief Adds an object to the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child The object to insert - * @param reference The object to be used as reference - * - * @return @c EINA_TRUE: Successfully added.\n - * @c EINA_FALSE: An error occurred. - * - * Inserts child in the box given by part, in the position marked by - * reference. - * - * @see edje_object_part_box_append() - * @see edje_object_part_box_prepend() - * @see edje_object_part_box_insert_at() - */ -EAPI Eina_Bool edje_object_part_box_insert_before (Evas_Object *obj, const char *part, Evas_Object *child, const Evas_Object *reference); - -/** - * @brief Inserts an object to the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child The object to insert - * @param pos The position where to insert child - * - * @return @c EINA_TRUE: Successfully added.\n - * @c EINA_FALSE: An error occurred. - * - * Adds child to the box indicated by part, in the position given by - * pos. - * - * @see edje_object_part_box_append() - * @see edje_object_part_box_prepend() - * @see edje_object_part_box_insert_before() - */ -EAPI Eina_Bool edje_object_part_box_insert_at (Evas_Object *obj, const char *part, Evas_Object *child, unsigned int pos); - -/** - * @brief Removes an object from the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child The object to remove - * - * @return Pointer to the object removed, or @c NULL. - * - * Removes child from the box indicated by part. - * - * @see edje_object_part_box_remove_at() - * @see edje_object_part_box_remove_all() - */ -EAPI Evas_Object *edje_object_part_box_remove (Evas_Object *obj, const char *part, Evas_Object *child); - -/** - * @brief Removes an object from the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param pos The position index of the object (starts counting from 0) - * - * @return Pointer to the object removed, or @c NULL. - * - * Removes from the box indicated by part, the object in the position - * pos. - * - * @see edje_object_part_box_remove() - * @see edje_object_part_box_remove_all() - */ -EAPI Evas_Object *edje_object_part_box_remove_at (Evas_Object *obj, const char *part, unsigned int pos); - -/** - * @brief Removes all elements from the box. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param clear Delete objects on removal - * - * @return 1: Successfully cleared.\n - * 0: An error occurred. - * - * Removes all the external objects from the box indicated by part. - * Elements created from the theme will not be removed. - * - * @see edje_object_part_box_remove() - * @see edje_object_part_box_remove_at() - */ -EAPI Eina_Bool edje_object_part_box_remove_all (Evas_Object *obj, const char *part, Eina_Bool clear); - -/** - * @} - */ - -/** - * @ingroup Edje_Part_Table - * - * @{ - */ - -/** - * @brief Retrieve a child from a table - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param col The column of the child to get - * @param row The row of the child to get - * @return The child Evas_Object - */ -EAPI Evas_Object *edje_object_part_table_child_get (const Evas_Object *obj, const char *part, unsigned int col, unsigned int row); - -/** - * @brief Packs an object into the table. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child_obj The object to pack in - * @param col The column to place it in - * @param row The row to place it in - * @param colspan Columns the child will take - * @param rowspan Rows the child will take - * - * @return @c EINA_TRUE object was added, @c EINA_FALSE on failure - * - * Packs an object into the table indicated by part. - */ -EAPI Eina_Bool edje_object_part_table_pack (Evas_Object *obj, const char *part, Evas_Object *child_obj, unsigned short col, unsigned short row, unsigned short colspan, unsigned short rowspan); - -/** - * @brief Removes an object from the table. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param child_obj The object to pack in - * - * @return @c EINA_TRUE object removed, @c EINA_FALSE on failure - * - * Removes an object from the table indicated by part. - */ -EAPI Eina_Bool edje_object_part_table_unpack (Evas_Object *obj, const char *part, Evas_Object *child_obj); - -/** - * @brief Gets the number of columns and rows the table has. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param cols Pointer where to store number of columns (can be NULL) - * @param rows Pointer where to store number of rows (can be NULL) - * - * @return @c EINA_TRUE get some data, @c EINA_FALSE on failure - * - * Retrieves the size of the table in number of columns and rows. - */ -EAPI Eina_Bool edje_object_part_table_col_row_size_get (const Evas_Object *obj, const char *part, int *cols, int *rows); - -/** - * @brief Removes all object from the table. - * - * @param obj A valid Evas_Object handle - * @param part The part name - * @param clear If set, will delete subobjs on remove - * - * @return @c EINA_TRUE clear the table, @c EINA_FALSE on failure - * - * Removes all object from the table indicated by part, except the - * internal ones set from the theme. - */ -EAPI Eina_Bool edje_object_part_table_clear (Evas_Object *obj, const char *part, Eina_Bool clear); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Text_Class - * - * @{ - */ - -/** - * @brief Sets Edje text class. - * - * @param obj A valid Evas_Object handle - * @param text_class The text class name - * @param font Font name - * @param size Font Size - * - * @return @c EINA_TRUE, on success or @c EINA_FALSE, on error - * - * This function sets the text class for the Edje. - * - */ -EAPI Eina_Bool edje_object_text_class_set (Evas_Object *obj, const char *text_class, const char *font, Evas_Font_Size size); - -/** - * @} - */ - -/** - * @ingroup Edje_Perspective - * - * @{ - */ - -/** - * Set the given perspective object on this Edje object. - * - * @param obj The Edje object on the perspective will be set. - * @param ps The perspective object that will be used. - * - * Make the given perspective object be the default perspective for this Edje - * object. - * - * There can be only one perspective object per Edje object, and if a - * previous one was set, it will be removed and the new perspective object - * will be used. - * - * An Edje perspective will only affect a part if it doesn't point to another - * part to be used as perspective. - * - * @see edje_object_perspective_new() - * @see edje_object_perspective_get() - * @see edje_perspective_set() - */ -EAPI void edje_object_perspective_set (Evas_Object *obj, Edje_Perspective *ps); - -/** - * Get the current perspective used on this Edje object. - * - * @param obj the given Edje object. - * @return The perspective object being used on this Edje object. Or @c NULL - * if there was none, and on errors. - * - * @see edje_object_perspective_set() - */ -EAPI const Edje_Perspective *edje_object_perspective_get (const Evas_Object *obj); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Group - * - * @{ - */ - -/** * @brief Instantiate a new Edje object * * @param evas A valid Evas handle, the canvas to place the new object @@ -2436,97 +52,6 @@ EAPI const Edje_Perspective *edje_object_perspective_get (const Evas_Object EAPI Evas_Object *edje_object_add (Evas *evas); /** - * @brief Preload the images on the Edje Object in the background. - * - * @param obj A handle to an Edje object - * @param cancel @c EINA_FALSE will add it the preloading work queue, - * @c EINA_TRUE will remove it (if it was issued before). - * @return @c EINA_FASLE if obj was not a valid Edje object - * otherwise @c EINA_TRUE - * - * This function requests the preload of all data images (on the given - * object) in the background. The work is queued before being processed - * (because there might be other pending requests of this type). - * It emits a signal "preload,done" when finished. - * - * @note Use @c EINA_TRUE on scenarios where you don't need - * the image data preloaded anymore. - */ -EAPI Eina_Bool edje_object_preload (Evas_Object *obj, Eina_Bool cancel); - -/** - * @} - */ - -/** - * @ingroup Edje_Object_Communication_Interface_Signal - * - * @{ - */ - -/** - * @brief Add a callback for an arriving Edje signal, emitted by - * a given Edje object. - * - * @param obj A handle to an Edje object - * @param emission The signal's "emission" string - * @param source The signal's "source" string - * @param func The callback function to be executed when the signal is - * emitted. - * @param data A pointer to data to pass in to @p func. - * - * Edje signals are one of the communication interfaces between - * @b code and a given Edje object's @b theme. With signals, one can - * communicate two string values at a time, which are: - * - "emission" value: the name of the signal, in general - * - "source" value: a name for the signal's context, in general - * - * Though there are those common uses for the two strings, one is free - * to use them however they like. - * - * This function adds a callback function to a signal emitted by @a obj, to - * be issued every time an EDC program like the following - * @code - * program { - * name: "emit_example"; - * action: SIGNAL_EMIT "a_signal" "a_source"; - * } - * @endcode - * is run, if @p emission and @p source are given those same values, - * here. - * - * Signal callback registration is powerful, in the way that @b blobs - * may be used to match multiple signals at once. All the @c - * "*?[\" set of @c fnmatch() operators can be used, both for @p - * emission and @p source. - * - * Edje has @b internal signals it will emit, automatically, on - * various actions taking place on group parts. For example, the mouse - * cursor being moved, pressed, released, etc., over a given part's - * area, all generate individual signals. - * - * By using something like - * @code - * edje_object_signal_callback_add(obj, "mouse,down,*", "button.*", - * signal_cb, NULL); - * @endcode - * being @c "button.*" the pattern for the names of parts implementing - * buttons on an interface, you'd be registering for notifications on - * events of mouse buttons being pressed down on either of those parts - * (those events all have the @c "mouse,down," common prefix on their - * names, with a suffix giving the button number). The actual emission - * and source strings of an event will be passed in as the @a emission - * and @a source parameters of the callback function (e.g. @c - * "mouse,down,2" and @c "button.close"), for each of those events. - * - * @note See @ref edcref "the syntax" for EDC files - * @see edje_object_signal_emit() on how to emits Edje signals from - * code to a an object - * @see edje_object_signal_callback_del_full() - */ -EAPI void edje_object_signal_callback_add (Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func, void *data); - -/** * @brief Remove a signal-triggered callback from an object. * * @param obj A valid Evas_Object handle. @@ -2573,99 +98,58 @@ EAPI void *edje_object_signal_callback_del (Evas_Object *obj, const char EAPI void *edje_object_signal_callback_del_full(Evas_Object *obj, const char *emission, const char *source, Edje_Signal_Cb func, void *data); /** - * @brief Send/emit an Edje signal to a given Edje object - * - * @param obj A handle to an Edje object - * @param emission The signal's "emission" string - * @param source The signal's "source" string - * - * This function sends a signal to the object @a obj. An Edje program, - * at @p obj's EDC specification level, can respond to a signal by - * having declared matching @c 'signal' and @c 'source' fields on its - * block (see @ref edcref "the syntax" for EDC files). + * @brief Delete the object color class. * - * As an example, - * @code - * edje_object_signal_emit(obj, "a_signal", ""); - * @endcode - * would trigger a program which had an EDC declaration block like - * @code - * program { - * name: "a_program"; - * signal: "a_signal"; - * source: ""; - * action: ... - * } - * @endcode + * @param obj The edje object's reference. + * @param color_class The color class to be deleted. * - * @see edje_object_signal_callback_add() for more on Edje signals. - */ -EAPI void edje_object_signal_emit (Evas_Object *obj, const char *emission, const char *source); -/** - * @} - */ - -/** - * @ingroup Edje_Object_Communication_Interface_Message + * This function deletes any values at the object level for the + * specified object and color class. + * @note Deleting the color class will revert it to the values + * defined by edje_color_class_set() or the color class + * defined in the theme file. * - * @{ + * Deleting the color class will emit the signal "color_class,del" + * for the given Edje object. */ + EAPI void edje_object_color_class_del (Evas_Object *obj, const char *color_class); -/** - * @brief Send an (Edje) message to a given Edje object - * - * @param obj A handle to an Edje object - * @param type The type of message to send to @p obj - * @param id A identification number for the message to be sent - * @param msg The message's body, a struct depending on @p type - * - * This function sends an Edje message to @p obj and to all of its - * child objects, if it has any (swallowed objects are one kind of - * child object). @p type and @p msg @b must be matched accordingly, - * as documented in #Edje_Message_Type. + /** + * @brief Set the object minimum size. * - * The @p id argument as a form of code and theme defining a common - * interface on message communication. One should define the same IDs - * on both code and EDC declaration (see @ref edcref "the syntax" for - * EDC files), to individualize messages (binding them to a given - * context). + * @param obj A valid Evas_Object handle + * @param minw The minimum width + * @param minh The minimum height * - * The function to handle messages arriving @b from @b obj is set with - * edje_object_message_handler_set(). + * This sets the minimum size restriction for the object. */ -EAPI void edje_object_message_send (Evas_Object *obj, Edje_Message_Type type, int id, void *msg); +EAPI void edje_extern_object_min_size_set (Evas_Object *obj, Evas_Coord minw, Evas_Coord minh); /** - * @brief Set an Edje message handler function for a given Edje object. - * - * @param obj A handle to an Edje object - * @param func The function to handle messages @b coming from @p obj - * @param data Auxiliary data to be passed to @p func - * - * For scriptable programs on an Edje object's defining EDC file which - * send messages with the @c send_message() primitive, one can attach - * handler functions, to be called in the code which creates - * that object (see @ref edcref "the syntax" for EDC files). + * @brief Set the object maximum size. * - * This function associates a message handler function and the - * attached data pointer to the object @p obj. + * @param obj A valid Evas_Object handle + * @param maxw The maximum width + * @param maxh The maximum height * - * @see edje_object_message_send() + * This sets the maximum size restriction for the object. */ -EAPI void edje_object_message_handler_set (Evas_Object *obj, Edje_Message_Handler_Cb func, void *data); +EAPI void edje_extern_object_max_size_set (Evas_Object *obj, Evas_Coord maxw, Evas_Coord maxh); /** - * @brief Process an object's message queue. - * - * @param obj A handle to an Edje object. + * @brief Set the object aspect size. * - * This function goes through the object message queue processing the - * pending messages for @b this specific Edje object. Normally they'd - * be processed only at idle time. + * @param obj A valid Evas_Object handle + * @param aspect The aspect control axes + * @param aw The aspect radio width + * @param ah The aspect ratio height * + * This sets the desired aspect ratio to keep an object that will be + * swallowed by Edje. The width and height define a preferred size + * ASPECT and the object may be scaled to be larger or smaller, but + * retaining the relative scale of both aspect width and height. */ -EAPI void edje_object_message_signal_process (Evas_Object *obj); +EAPI void edje_extern_object_aspect_set (Evas_Object *obj, Edje_Aspect_Control aspect, Evas_Coord aw, Evas_Coord ah); -/** - * @} - */ +#include "edje.eo.legacy.h" +#include "edje_edit.eo.legacy.h" -- 2.7.4