2 # include "elementary_config.h"
5 #include <Elementary.h>
6 #include <Elementary_Cursor.h>
9 #include "elm_widget_menu.h"
11 EAPI Eo_Op ELM_OBJ_WIN_BASE_ID = EO_NOOP;
13 #define MY_CLASS ELM_OBJ_WIN_CLASS
15 #define MY_CLASS_NAME "Elm_Win"
16 #define MY_CLASS_NAME_LEGACY "elm_win"
18 static const Elm_Win_Trap *trap = NULL;
20 #define TRAP(sd, name, ...) \
23 if ((!trap) || (!trap->name) || \
25 (trap->name(sd->trap_data, sd->obj, ## __VA_ARGS__)))) \
26 ecore_evas_##name(sd->ee, ##__VA_ARGS__); \
30 #define ELM_WIN_DATA_GET(o, sd) \
31 Elm_Win_Smart_Data * sd = eo_data_scope_get(o, MY_CLASS)
33 #define ELM_WIN_DATA_GET_OR_RETURN(o, ptr) \
34 ELM_WIN_DATA_GET(o, ptr); \
37 CRI("No widget data for object %p (%s)", \
38 o, evas_object_type_get(o)); \
42 #define ELM_WIN_DATA_GET_OR_RETURN_VAL(o, ptr, val) \
43 ELM_WIN_DATA_GET(o, ptr); \
46 CRI("No widget data for object %p (%s)", \
47 o, evas_object_type_get(o)); \
51 #define ELM_WIN_CHECK(obj) \
52 if (!obj || !eo_isa(obj, MY_CLASS)) \
55 #define ENGINE_GET() (_elm_preferred_engine ? _elm_preferred_engine : (_elm_config->engine ? _elm_config->engine : ""))
56 #define ENGINE_COMPARE(name) (!strcmp(ENGINE_GET(), name))
58 typedef struct _Elm_Win_Smart_Data Elm_Win_Smart_Data;
60 struct _Elm_Win_Smart_Data
64 Evas_Object *parent; /* parent *window* object*/
65 Evas_Object *img_obj, *frame_obj;
66 Evas_Object *client_obj; /* rect representing the client */
67 Evas_Object *spacer_obj;
70 Evas_Object *obj; /* The object itself */
71 #ifdef HAVE_ELEMENTARY_X
75 Ecore_Event_Handler *client_message_handler;
76 Ecore_Event_Handler *property_handler;
79 #ifdef HAVE_ELEMENTARY_WAYLAND
86 Ecore_Job *deferred_resize_job;
87 Ecore_Job *deferred_child_eval_job;
90 Elm_Win_Keyboard_Mode kbdmode;
91 Elm_Win_Indicator_Mode indmode;
92 Elm_Win_Indicator_Opacity_Mode ind_o_mode;
101 int *autodel_clear, rot;
110 Evas_Object *obj, *hot_obj;
115 Evas_Object *fobj; /* focus highlight edje object */
120 Eina_Bool visible : 1;
121 Eina_Bool in_theme: 1; /**< focus highlight is handled by theme.
122 this is set true if edc data item "focus_highlight" is set to "on" during focus in callback. */
126 Ecore_Job *reconf_job;
128 Eina_Bool enabled : 1;
129 Eina_Bool theme_changed : 1; /* set true when the focus theme is changed */
130 Eina_Bool animate : 1; /* set true when the focus highlight animate is enabled */
131 Eina_Bool animate_supported : 1; /* set true when the focus highlight animate is supported by theme */
132 Eina_Bool geometry_changed : 1;
137 const char *icon_name;
140 Evas_Object *main_menu;
145 const char **available_list;
150 int preferred_rot; /* indicates preferred rotation value, -1 means invalid. */
151 int *rots; /* indicates available rotations */
152 unsigned int count; /* number of elements in available rotations */
153 Eina_Bool wm_supported : 1; /* set true when the window manager support window rotation */
154 Eina_Bool use : 1; /* set ture when application use window manager rotation. */
160 int size_base_w, size_base_h;
161 int size_step_w, size_step_h;
163 Eina_Bool urgent : 1;
165 Eina_Bool demand_attention : 1;
166 Eina_Bool autodel : 1;
167 Eina_Bool constrain : 1;
168 Eina_Bool resizing : 1;
169 Eina_Bool iconified : 1;
170 Eina_Bool withdrawn : 1;
171 Eina_Bool sticky : 1;
172 Eina_Bool fullscreen : 1;
173 Eina_Bool maximized : 1;
174 Eina_Bool skip_focus : 1;
175 Eina_Bool floating : 1;
178 static const char SIG_DELETE_REQUEST[] = "delete,request";
179 static const char SIG_FOCUS_OUT[] = "focus,out"; // deprecated. use "focused" instead.
180 static const char SIG_FOCUS_IN[] = "focus,in"; // deprecated. use "unfocused" instead.
181 static const char SIG_MOVED[] = "moved";
182 static const char SIG_WITHDRAWN[] = "withdrawn";
183 static const char SIG_ICONIFIED[] = "iconified";
184 static const char SIG_NORMAL[] = "normal";
185 static const char SIG_STICK[] = "stick";
186 static const char SIG_UNSTICK[] = "unstick";
187 static const char SIG_FULLSCREEN[] = "fullscreen";
188 static const char SIG_UNFULLSCREEN[] = "unfullscreen";
189 static const char SIG_MAXIMIZED[] = "maximized";
190 static const char SIG_UNMAXIMIZED[] = "unmaximized";
191 static const char SIG_IOERR[] = "ioerr";
192 static const char SIG_INDICATOR_PROP_CHANGED[] = "indicator,prop,changed";
193 static const char SIG_ROTATION_CHANGED[] = "rotation,changed";
194 static const char SIG_PROFILE_CHANGED[] = "profile,changed";
195 static const char SIG_FOCUSED[] = "focused";
196 static const char SIG_UNFOCUSED[] = "unfocused";
197 static const char SIG_WM_ROTATION_CHANGED[] = "wm,rotation,changed";
199 static const Evas_Smart_Cb_Description _smart_callbacks[] = {
200 {SIG_DELETE_REQUEST, ""},
209 {SIG_FULLSCREEN, ""},
210 {SIG_UNFULLSCREEN, ""},
212 {SIG_UNMAXIMIZED, ""},
214 {SIG_INDICATOR_PROP_CHANGED, ""},
215 {SIG_ROTATION_CHANGED, ""},
216 {SIG_PROFILE_CHANGED, ""},
219 {SIG_WM_ROTATION_CHANGED, ""},
223 Eina_List *_elm_win_list = NULL;
224 int _elm_win_deferred_free = 0;
226 static int _elm_win_count = 0;
228 static Eina_Bool _elm_win_auto_throttled = EINA_FALSE;
230 static Ecore_Job *_elm_win_state_eval_job = NULL;
233 _elm_win_on_resize_obj_changed_size_hints(void *data,
237 #ifdef HAVE_ELEMENTARY_X
238 static void _elm_win_xwin_update(Elm_Win_Smart_Data *sd);
241 EAPI double _elm_startup_time = 0;
244 _elm_win_first_frame_do(void *data, Evas *e EINA_UNUSED, void *event_info EINA_UNUSED)
246 double end = ecore_time_unix_get();
254 case 'T': fprintf(stderr, "Startup time: '%f' - '%f' = '%f' sec\n", end, _elm_startup_time, end - _elm_startup_time);
258 evas_event_callback_del_full(e, EVAS_CALLBACK_RENDER_POST, _elm_win_first_frame_do, data);
262 _elm_win_state_eval(void *data EINA_UNUSED)
266 int _elm_win_count_shown = 0;
267 int _elm_win_count_iconified = 0;
268 int _elm_win_count_withdrawn = 0;
270 _elm_win_state_eval_job = NULL;
272 if (_elm_config->auto_norender_withdrawn)
274 EINA_LIST_FOREACH(_elm_win_list, l, obj)
276 if ((elm_win_withdrawn_get(obj)) ||
277 ((elm_win_iconified_get(obj) &&
278 (_elm_config->auto_norender_iconified_same_as_withdrawn))))
280 if (!evas_object_data_get(obj, "__win_auto_norender"))
282 Evas *evas = evas_object_evas_get(obj);
284 elm_win_norender_push(obj);
285 evas_object_data_set(obj, "__win_auto_norender", obj);
287 if (_elm_config->auto_flush_withdrawn)
289 edje_file_cache_flush();
290 edje_collection_cache_flush();
291 evas_image_cache_flush(evas);
292 evas_font_cache_flush(evas);
294 if (_elm_config->auto_dump_withdrawn)
296 evas_render_dump(evas);
302 if (evas_object_data_get(obj, "__win_auto_norender"))
304 elm_win_norender_pop(obj);
305 evas_object_data_del(obj, "__win_auto_norender");
310 if (((_elm_config->auto_throttle) &&
311 (elm_policy_get(ELM_POLICY_THROTTLE) != ELM_POLICY_THROTTLE_NEVER)) ||
312 (elm_policy_get(ELM_POLICY_THROTTLE) == ELM_POLICY_THROTTLE_HIDDEN_ALWAYS))
314 if (_elm_win_count == 0)
316 if (_elm_win_auto_throttled)
318 ecore_throttle_adjust(-_elm_config->auto_throttle_amount);
319 _elm_win_auto_throttled = EINA_FALSE;
324 EINA_LIST_FOREACH(_elm_win_list, l, obj)
326 if (elm_win_withdrawn_get(obj))
327 _elm_win_count_withdrawn++;
328 else if (elm_win_iconified_get(obj))
329 _elm_win_count_iconified++;
330 else if (evas_object_visible_get(obj))
331 _elm_win_count_shown++;
333 if (_elm_win_count_shown <= 0)
335 if (!_elm_win_auto_throttled)
337 ecore_throttle_adjust(_elm_config->auto_throttle_amount);
338 _elm_win_auto_throttled = EINA_TRUE;
343 if (_elm_win_auto_throttled)
345 ecore_throttle_adjust(-_elm_config->auto_throttle_amount);
346 _elm_win_auto_throttled = EINA_FALSE;
354 _elm_win_state_eval_queue(void)
356 ecore_job_del(_elm_win_state_eval_job);
357 _elm_win_state_eval_job = ecore_job_add(_elm_win_state_eval, NULL);
360 // example shot spec (wait 0.1 sec then save as my-window.png):
361 // ELM_ENGINE="shot:delay=0.1:file=my-window.png"
364 _shot_delay_get(Elm_Win_Smart_Data *sd)
367 char *d = strdup(sd->shot.info);
370 for (p = (char *)sd->shot.info; *p; p++)
372 if (!strncmp(p, "delay=", 6))
376 for (pd = d, p += 6; (*p) && (*p != ':'); p++, pd++)
392 _shot_file_get(Elm_Win_Smart_Data *sd)
395 char *tmp = strdup(sd->shot.info);
396 char *repname = NULL;
398 if (!tmp) return NULL;
400 for (p = (char *)sd->shot.info; *p; p++)
402 if (!strncmp(p, "file=", 5))
405 if (!sd->shot.repeat_count) return tmp;
408 char *dotptr = strrchr(tmp, '.');
411 size_t size = sizeof(char) * (strlen(tmp) + 16);
412 repname = malloc(size);
413 strncpy(repname, tmp, dotptr - tmp);
414 snprintf(repname + (dotptr - tmp), size -
415 (dotptr - tmp), "%03i",
416 sd->shot.shot_counter + 1);
417 strcat(repname, dotptr);
425 if (!sd->shot.repeat_count) return strdup("out.png");
427 repname = malloc(sizeof(char) * 24);
428 snprintf(repname, sizeof(char) * 24, "out%03i.png",
429 sd->shot.shot_counter + 1);
435 _shot_repeat_count_get(Elm_Win_Smart_Data *sd)
438 char *d = strdup(sd->shot.info);
441 for (p = (char *)sd->shot.info; *p; p++)
443 if (!strncmp(p, "repeat=", 7))
447 for (pd = d, p += 7; (*p) && (*p != ':'); p++, pd++)
454 if (v > 1000) v = 999;
465 _shot_key_get(Elm_Win_Smart_Data *sd EINA_UNUSED)
471 _shot_flags_get(Elm_Win_Smart_Data *sd EINA_UNUSED)
477 _shot_do(Elm_Win_Smart_Data *sd)
481 unsigned int *pixels;
483 char *file, *key, *flags;
485 ecore_evas_manual_render(sd->ee);
486 pixels = (void *)ecore_evas_buffer_pixels_get(sd->ee);
489 ecore_evas_geometry_get(sd->ee, NULL, NULL, &w, &h);
490 if ((w < 1) || (h < 1)) return;
492 file = _shot_file_get(sd);
495 key = _shot_key_get(sd);
496 flags = _shot_flags_get(sd);
497 ee = ecore_evas_buffer_new(1, 1);
498 o = evas_object_image_add(ecore_evas_get(ee));
499 evas_object_image_alpha_set(o, ecore_evas_alpha_get(sd->ee));
500 evas_object_image_size_set(o, w, h);
501 evas_object_image_data_set(o, pixels);
502 if (!evas_object_image_save(o, file, key, flags))
504 ERR("Cannot save window to '%s' (key '%s', flags '%s')",
511 if (sd->shot.repeat_count) sd->shot.shot_counter++;
515 _shot_delay(void *data)
517 ELM_WIN_DATA_GET(data, sd);
520 if (sd->shot.repeat_count)
522 int remainshot = (sd->shot.repeat_count - sd->shot.shot_counter);
523 if (remainshot > 0) return EINA_TRUE;
525 sd->shot.timer = NULL;
532 _shot_init(Elm_Win_Smart_Data *sd)
534 if (!sd->shot.info) return;
536 sd->shot.repeat_count = _shot_repeat_count_get(sd);
537 sd->shot.shot_counter = 0;
541 _shot_handle(Elm_Win_Smart_Data *sd)
543 if (!sd->shot.info) return;
546 sd->shot.timer = ecore_timer_add(_shot_delay_get(sd), _shot_delay,
550 /* elm-win specific associate, does the trap while ecore_evas_object_associate()
553 static Elm_Win_Smart_Data *
554 _elm_win_associate_get(const Ecore_Evas *ee)
556 ELM_WIN_DATA_GET(ecore_evas_data_get(ee, "elm_win"), sd);
560 /* Interceptors Callbacks */
562 _elm_win_obj_intercept_raise(void *data, Evas_Object *obj EINA_UNUSED)
564 ELM_WIN_DATA_GET(data, sd);
569 _elm_win_obj_intercept_lower(void *data, Evas_Object *obj EINA_UNUSED)
571 ELM_WIN_DATA_GET(data, sd);
576 _elm_win_obj_intercept_stack_above(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, Evas_Object *above EINA_UNUSED)
578 INF("TODO: %s", __FUNCTION__);
582 _elm_win_obj_intercept_stack_below(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, Evas_Object *below EINA_UNUSED)
584 INF("TODO: %s", __FUNCTION__);
588 _elm_win_obj_intercept_layer_set(void *data, Evas_Object *obj EINA_UNUSED, int l)
590 ELM_WIN_DATA_GET(data, sd);
591 TRAP(sd, layer_set, l);
594 /* Event Callbacks */
597 _elm_win_obj_callback_changed_size_hints(void *data, Evas *e EINA_UNUSED, Evas_Object *obj, void *event_info EINA_UNUSED)
599 ELM_WIN_DATA_GET(data, sd);
602 evas_object_size_hint_min_get(obj, &w, &h);
603 TRAP(sd, size_min_set, w, h);
605 evas_object_size_hint_max_get(obj, &w, &h);
608 TRAP(sd, size_max_set, w, h);
610 /* end of elm-win specific associate */
613 _elm_win_move(Ecore_Evas *ee)
615 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
618 EINA_SAFETY_ON_NULL_RETURN(sd);
620 ecore_evas_geometry_get(ee, &x, &y, NULL, NULL);
623 evas_object_smart_callback_call(sd->obj, SIG_MOVED, NULL);
627 _elm_win_resize_job(void *data)
629 ELM_WIN_DATA_GET(data, sd);
632 sd->deferred_resize_job = NULL;
633 ecore_evas_request_geometry_get(sd->ee, NULL, NULL, &w, &h);
637 ecore_evas_screen_geometry_get(sd->ee, NULL, NULL, &sw, &sh);
646 evas_output_framespace_get(sd->evas, &fx, &fy, &fw, &fh);
647 evas_object_move(sd->frame_obj, -fx, -fy);
648 evas_object_resize(sd->frame_obj, w + fw, h + fh);
651 evas_object_resize(sd->obj, w, h);
652 evas_object_resize(sd->layout, w, h);
656 _elm_win_resize(Ecore_Evas *ee)
658 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
659 EINA_SAFETY_ON_NULL_RETURN(sd);
661 ecore_job_del(sd->deferred_resize_job);
662 sd->deferred_resize_job = ecore_job_add(_elm_win_resize_job, sd->obj);
666 _elm_win_mouse_in(Ecore_Evas *ee)
668 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
669 EINA_SAFETY_ON_NULL_RETURN(sd);
671 if (sd->resizing) sd->resizing = EINA_FALSE;
675 _elm_win_focus_highlight_reconfigure_job_stop(Elm_Win_Smart_Data *sd)
677 ELM_SAFE_FREE(sd->focus_highlight.reconf_job, ecore_job_del);
681 _elm_win_focus_highlight_visible_set(Elm_Win_Smart_Data *sd,
684 Evas_Object *fobj = sd->focus_highlight.fobj;
689 evas_object_show(fobj);
690 edje_object_signal_emit(fobj, "elm,action,focus,show", "elm");
694 edje_object_signal_emit(fobj, "elm,action,focus,hide", "elm");
699 _elm_win_focus_highlight_anim_setup(Elm_Win_Smart_Data *sd,
702 Evas_Coord tx, ty, tw, th;
703 Evas_Coord w, h, px, py, pw, ph;
704 Edje_Message_Int_Set *m;
705 Evas_Object *previous = sd->focus_highlight.prev.target;
706 Evas_Object *target = sd->focus_highlight.cur.target;
708 evas_object_geometry_get(sd->obj, NULL, NULL, &w, &h);
709 elm_widget_focus_highlight_geometry_get(target, &tx, &ty, &tw, &th);
710 elm_widget_focus_highlight_geometry_get(previous, &px, &py, &pw, &ph);
711 evas_object_move(obj, tx, ty);
712 evas_object_resize(obj, tw, th);
713 evas_object_clip_unset(obj);
715 m = alloca(sizeof(*m) + (sizeof(int) * 8));
725 edje_object_message_send(obj, EDJE_MESSAGE_INT_SET, 1, m);
729 _elm_win_focus_highlight_simple_setup(Elm_Win_Smart_Data *sd,
732 Evas_Object *clip, *target = sd->focus_highlight.cur.target;
733 Evas_Coord x, y, w, h;
735 clip = evas_object_clip_get(target);
736 elm_widget_focus_highlight_geometry_get(target, &x, &y, &w, &h);
738 evas_object_move(obj, x, y);
739 evas_object_resize(obj, w, h);
740 if (clip) evas_object_clip_set(obj, clip);
744 _elm_win_focus_highlight_reconfigure(Elm_Win_Smart_Data *sd)
746 Evas_Object *target = sd->focus_highlight.cur.target;
747 Evas_Object *previous = sd->focus_highlight.prev.target;
748 Evas_Object *fobj = sd->focus_highlight.fobj;
749 Eina_Bool visible_changed;
750 Eina_Bool common_visible;
751 const char *sig = NULL;
752 const char *focus_style_target = NULL;
753 const char *focus_style_previous = NULL;
755 _elm_win_focus_highlight_reconfigure_job_stop(sd);
757 visible_changed = (sd->focus_highlight.cur.visible !=
758 sd->focus_highlight.prev.visible);
760 if ((target == previous) && (!visible_changed) &&
761 (!sd->focus_highlight.geometry_changed) &&
762 (!sd->focus_highlight.theme_changed))
765 if ((previous) && (sd->focus_highlight.prev.in_theme))
766 elm_widget_signal_emit
767 (previous, "elm,action,focus_highlight,hide", "elm");
770 common_visible = EINA_FALSE;
771 else if (sd->focus_highlight.cur.in_theme)
773 common_visible = EINA_FALSE;
774 if (sd->focus_highlight.cur.visible)
775 sig = "elm,action,focus_highlight,show";
777 sig = "elm,action,focus_highlight,hide";
780 common_visible = sd->focus_highlight.cur.visible;
783 elm_widget_signal_emit(target, sig, "elm");
785 if ((!target) || (!common_visible) || (sd->focus_highlight.cur.in_theme))
789 focus_style_previous = elm_widget_focus_highlight_style_get(previous);
790 focus_style_target = elm_widget_focus_highlight_style_get(target);
792 if (sd->focus_highlight.theme_changed ||
793 (focus_style_target != focus_style_previous))
797 if (focus_style_target)
798 str = focus_style_target;
799 else if (sd->focus_highlight.style)
800 str = sd->focus_highlight.style;
804 elm_widget_theme_object_set
805 (sd->obj, fobj, "focus_highlight", "top", str);
806 sd->focus_highlight.theme_changed = EINA_FALSE;
808 if (sd->focus_highlight.animate)
810 str = edje_object_data_get(sd->focus_highlight.fobj, "animate");
811 sd->focus_highlight.animate_supported = ((str) && (!strcmp(str, "on")));
814 sd->focus_highlight.animate_supported = EINA_FALSE;
817 if ((sd->focus_highlight.animate_supported) && (previous) &&
818 (!sd->focus_highlight.prev.in_theme))
819 _elm_win_focus_highlight_anim_setup(sd, fobj);
821 _elm_win_focus_highlight_simple_setup(sd, fobj);
822 evas_object_raise(fobj);
825 _elm_win_focus_highlight_visible_set(sd, common_visible);
826 sd->focus_highlight.geometry_changed = EINA_FALSE;
827 sd->focus_highlight.prev = sd->focus_highlight.cur;
831 _elm_win_focus_highlight_reconfigure_job(void *data)
833 ELM_WIN_DATA_GET(data, sd);
834 _elm_win_focus_highlight_reconfigure(sd);
838 _elm_win_focus_highlight_reconfigure_job_start(Elm_Win_Smart_Data *sd)
840 ecore_job_del(sd->focus_highlight.reconf_job);
842 sd->focus_highlight.reconf_job = ecore_job_add(
843 _elm_win_focus_highlight_reconfigure_job, sd->obj);
847 _elm_win_focus_in(Ecore_Evas *ee)
849 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
851 unsigned int order = 0;
853 EINA_SAFETY_ON_NULL_RETURN(sd);
857 _elm_widget_top_win_focused_set(obj, EINA_TRUE);
858 if (!elm_widget_focus_order_get(obj)
859 || (obj == elm_widget_newest_focus_order_get(obj, &order, EINA_TRUE)))
861 elm_widget_focus_steal(obj);
864 elm_widget_focus_restore(obj);
865 evas_object_smart_callback_call(obj, SIG_FOCUS_IN, NULL);
866 evas_object_smart_callback_call(obj, SIG_FOCUSED, NULL);
867 sd->focus_highlight.cur.visible = EINA_TRUE;
868 _elm_win_focus_highlight_reconfigure_job_start(sd);
871 edje_object_signal_emit(sd->frame_obj, "elm,action,focus", "elm");
875 /* else if (sd->img_obj) */
881 _elm_win_focus_out(Ecore_Evas *ee)
883 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
886 EINA_SAFETY_ON_NULL_RETURN(sd);
890 elm_object_focus_set(obj, EINA_FALSE);
891 _elm_widget_top_win_focused_set(obj, EINA_FALSE);
892 evas_object_smart_callback_call(obj, SIG_FOCUS_OUT, NULL);
893 evas_object_smart_callback_call(obj, SIG_UNFOCUSED, NULL);
894 sd->focus_highlight.cur.visible = EINA_FALSE;
895 _elm_win_focus_highlight_reconfigure_job_start(sd);
898 edje_object_signal_emit(sd->frame_obj, "elm,action,unfocus", "elm");
902 _elm_access_object_highlight_disable(evas_object_evas_get(obj));
905 /* if (sd->img_obj) */
911 _elm_win_available_profiles_del(Elm_Win_Smart_Data *sd)
913 if (!sd->profile.available_list) return;
916 for (i = 0; i < sd->profile.count; i++)
917 ELM_SAFE_FREE(sd->profile.available_list[i], eina_stringshare_del);
918 sd->profile.count = 0;
919 ELM_SAFE_FREE(sd->profile.available_list, free);
923 _elm_win_profile_del(Elm_Win_Smart_Data *sd)
925 ELM_SAFE_FREE(sd->profile.name, eina_stringshare_del);
929 _elm_win_profile_set(Elm_Win_Smart_Data *sd, const char *profile)
931 Eina_Bool changed = EINA_FALSE;
934 if (sd->profile.name)
936 if (strcmp(sd->profile.name, profile) != 0)
938 eina_stringshare_replace(&(sd->profile.name), profile);
944 sd->profile.name = eina_stringshare_add(profile);
949 _elm_win_profile_del(sd);
955 _elm_win_profile_update(Elm_Win_Smart_Data *sd)
957 if (sd->profile.available_list)
959 Eina_Bool found = EINA_FALSE;
960 if (sd->profile.name)
963 for (i = 0; i < sd->profile.count; i++)
965 if (!strcmp(sd->profile.name,
966 sd->profile.available_list[i]))
974 /* If current profile is not present in an available profiles,
975 * change current profile to the 1st element of an array.
978 _elm_win_profile_set(sd, sd->profile.available_list[0]);
981 _elm_config_profile_set(sd->profile.name);
985 Eina_List *sub, *l = NULL;
987 sub = ecore_evas_sub_ecore_evas_list_get(sd->ee);
988 EINA_LIST_FOREACH(sub, l, ee2)
989 ecore_evas_window_profile_set(ee2, sd->profile.name);
991 evas_object_smart_callback_call(sd->obj, SIG_PROFILE_CHANGED, NULL);
995 _elm_win_state_change(Ecore_Evas *ee)
997 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
999 Eina_Bool ch_withdrawn = EINA_FALSE;
1000 Eina_Bool ch_sticky = EINA_FALSE;
1001 Eina_Bool ch_iconified = EINA_FALSE;
1002 Eina_Bool ch_fullscreen = EINA_FALSE;
1003 Eina_Bool ch_maximized = EINA_FALSE;
1004 Eina_Bool ch_profile = EINA_FALSE;
1005 Eina_Bool ch_wm_rotation = EINA_FALSE;
1006 const char *profile;
1008 EINA_SAFETY_ON_NULL_RETURN(sd);
1012 if (sd->withdrawn != ecore_evas_withdrawn_get(sd->ee))
1014 sd->withdrawn = ecore_evas_withdrawn_get(sd->ee);
1015 ch_withdrawn = EINA_TRUE;
1017 if (sd->sticky != ecore_evas_sticky_get(sd->ee))
1019 sd->sticky = ecore_evas_sticky_get(sd->ee);
1020 ch_sticky = EINA_TRUE;
1022 if (sd->iconified != ecore_evas_iconified_get(sd->ee))
1024 sd->iconified = ecore_evas_iconified_get(sd->ee);
1025 ch_iconified = EINA_TRUE;
1027 if (sd->fullscreen != ecore_evas_fullscreen_get(sd->ee))
1029 sd->fullscreen = ecore_evas_fullscreen_get(sd->ee);
1030 ch_fullscreen = EINA_TRUE;
1032 if (sd->maximized != ecore_evas_maximized_get(sd->ee))
1034 sd->maximized = ecore_evas_maximized_get(sd->ee);
1035 ch_maximized = EINA_TRUE;
1038 profile = ecore_evas_window_profile_get(sd->ee);
1039 ch_profile = _elm_win_profile_set(sd, profile);
1043 if (sd->rot != ecore_evas_rotation_get(sd->ee))
1045 sd->rot = ecore_evas_rotation_get(sd->ee);
1046 ch_wm_rotation = EINA_TRUE;
1050 _elm_win_state_eval_queue();
1052 if ((ch_withdrawn) || (ch_iconified))
1055 evas_object_smart_callback_call(obj, SIG_WITHDRAWN, NULL);
1056 else if (sd->iconified)
1057 evas_object_smart_callback_call(obj, SIG_ICONIFIED, NULL);
1059 evas_object_smart_callback_call(obj, SIG_NORMAL, NULL);
1064 evas_object_smart_callback_call(obj, SIG_STICK, NULL);
1066 evas_object_smart_callback_call(obj, SIG_UNSTICK, NULL);
1071 evas_object_smart_callback_call(obj, SIG_FULLSCREEN, NULL);
1073 evas_object_smart_callback_call(obj, SIG_UNFULLSCREEN, NULL);
1078 evas_object_smart_callback_call(obj, SIG_MAXIMIZED, NULL);
1080 evas_object_smart_callback_call(obj, SIG_UNMAXIMIZED, NULL);
1084 _elm_win_profile_update(sd);
1088 evas_object_size_hint_min_set(obj, -1, -1);
1089 evas_object_size_hint_max_set(obj, -1, -1);
1090 #ifdef HAVE_ELEMENTARY_X
1091 _elm_win_xwin_update(sd);
1093 elm_widget_orientation_set(obj, sd->rot);
1094 evas_object_smart_callback_call(obj, SIG_ROTATION_CHANGED, NULL);
1095 evas_object_smart_callback_call(obj, SIG_WM_ROTATION_CHANGED, NULL);
1100 _elm_win_smart_focus_next_manager_is(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list)
1102 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1107 _elm_win_smart_focus_next(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1109 Elm_Focus_Direction dir = va_arg(*list, Elm_Focus_Direction);
1110 Evas_Object **next = va_arg(*list, Evas_Object **);
1111 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1112 if (ret) *ret = EINA_FALSE;
1114 ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
1116 const Eina_List *items;
1117 void *(*list_data_get)(const Eina_List *list);
1122 if (!(items = elm_widget_focus_custom_chain_get(obj)))
1124 items = wd->subobjs;
1128 list_data_get = eina_list_data_get;
1130 elm_widget_focus_list_next_get(obj, items, list_data_get, dir, next);
1134 if (ret) *ret = EINA_TRUE;
1138 *next = (Evas_Object *)obj;
1143 _elm_win_smart_focus_direction_manager_is(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list)
1145 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1150 _elm_win_smart_focus_direction(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1152 const Evas_Object *base = va_arg(*list, Evas_Object *);
1153 double degree = va_arg(*list, double);
1154 Evas_Object **direction = va_arg(*list, Evas_Object **);
1155 double *weight = va_arg(*list, double *);
1156 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1157 if (ret) *ret = EINA_FALSE;
1158 Eina_Bool int_ret = EINA_FALSE;
1160 const Eina_List *items;
1161 void *(*list_data_get)(const Eina_List *list);
1163 ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
1168 if (!(items = elm_widget_focus_custom_chain_get(obj)))
1169 items = wd->subobjs;
1171 list_data_get = eina_list_data_get;
1173 int_ret = elm_widget_focus_list_direction_get
1174 (obj, base, items, list_data_get, degree, direction, weight);
1175 if (ret) *ret = int_ret;
1180 _elm_win_smart_on_focus(Eo *obj, void *_pd, va_list *list)
1182 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1183 if (ret) *ret = EINA_TRUE;
1184 Elm_Win_Smart_Data *sd = _pd;
1185 Eina_Bool int_ret = EINA_FALSE;
1187 eo_do_super(obj, MY_CLASS, elm_wdg_on_focus(&int_ret));
1188 if (!int_ret) return;
1191 evas_object_focus_set(sd->img_obj, elm_widget_focus_get(obj));
1193 evas_object_focus_set(obj, elm_widget_focus_get(obj));
1197 _elm_win_smart_event(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1199 Evas_Object *src = va_arg(*list, Evas_Object *);
1200 Evas_Callback_Type type = va_arg(*list, Evas_Callback_Type);
1201 Evas_Event_Key_Down *ev = va_arg(*list, void *);
1202 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1204 if (ret) *ret = EINA_FALSE;
1207 if (elm_widget_disabled_get(obj)) return;
1208 if (type != EVAS_CALLBACK_KEY_DOWN) return;
1210 if ((!strcmp(ev->key, "Tab")) ||
1211 (!strcmp(ev->key, "ISO_Left_Tab")))
1213 if (evas_key_modifier_is_set(ev->modifiers, "Control") ||
1214 evas_key_modifier_is_set(ev->modifiers, "Alt"))
1216 if (evas_key_modifier_is_set(ev->modifiers, "Shift"))
1217 elm_widget_focus_cycle(obj, ELM_FOCUS_PREVIOUS);
1219 elm_widget_focus_cycle(obj, ELM_FOCUS_NEXT);
1223 else if ((!strcmp(ev->key, "Left")) ||
1224 ((!strcmp(ev->key, "KP_Left")) && (!ev->string)))
1226 elm_widget_focus_cycle(obj, ELM_FOCUS_LEFT);
1230 else if ((!strcmp(ev->key, "Right")) ||
1231 ((!strcmp(ev->key, "KP_Right")) && (!ev->string)))
1233 elm_widget_focus_cycle(obj, ELM_FOCUS_RIGHT);
1237 else if ((!strcmp(ev->key, "Up")) ||
1238 ((!strcmp(ev->key, "KP_Up")) && (!ev->string)))
1240 elm_widget_focus_cycle(obj, ELM_FOCUS_UP);
1244 else if ((!strcmp(ev->key, "Down")) ||
1245 ((!strcmp(ev->key, "KP_Down")) && (!ev->string)))
1247 elm_widget_focus_cycle(obj, ELM_FOCUS_DOWN);
1255 ev->event_flags |= EVAS_EVENT_FLAG_ON_HOLD;
1256 if (ret) *ret = EINA_TRUE;
1260 _deferred_ecore_evas_free(void *data)
1262 ecore_evas_free(data);
1263 _elm_win_deferred_free--;
1267 _elm_win_smart_show(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
1269 Elm_Win_Smart_Data *sd = _pd;
1271 if (!evas_object_visible_get(obj))
1272 _elm_win_state_eval_queue();
1273 eo_do_super(obj, MY_CLASS, evas_obj_smart_show());
1277 if (sd->shot.info) _shot_handle(sd);
1281 _elm_win_smart_hide(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
1283 Elm_Win_Smart_Data *sd = _pd;
1285 if (evas_object_visible_get(obj))
1286 _elm_win_state_eval_queue();
1287 eo_do_super(obj, MY_CLASS, evas_obj_smart_hide());
1293 evas_object_hide(sd->frame_obj);
1297 evas_object_hide(sd->img_obj);
1299 if (sd->pointer.obj)
1301 evas_object_hide(sd->pointer.obj);
1302 ecore_evas_hide(sd->pointer.ee);
1307 _elm_win_on_parent_del(void *data,
1308 Evas *e EINA_UNUSED,
1310 void *event_info EINA_UNUSED)
1312 ELM_WIN_DATA_GET(data, sd);
1314 if (obj == sd->parent) sd->parent = NULL;
1318 _elm_win_focus_target_move(void *data,
1319 Evas *e EINA_UNUSED,
1320 Evas_Object *obj EINA_UNUSED,
1321 void *event_info EINA_UNUSED)
1323 ELM_WIN_DATA_GET(data, sd);
1325 sd->focus_highlight.geometry_changed = EINA_TRUE;
1326 _elm_win_focus_highlight_reconfigure_job_start(sd);
1330 _elm_win_focus_target_resize(void *data,
1331 Evas *e EINA_UNUSED,
1332 Evas_Object *obj EINA_UNUSED,
1333 void *event_info EINA_UNUSED)
1335 ELM_WIN_DATA_GET(data, sd);
1337 sd->focus_highlight.geometry_changed = EINA_TRUE;
1338 _elm_win_focus_highlight_reconfigure_job_start(sd);
1342 _elm_win_focus_target_del(void *data,
1343 Evas *e EINA_UNUSED,
1344 Evas_Object *obj EINA_UNUSED,
1345 void *event_info EINA_UNUSED)
1347 ELM_WIN_DATA_GET(data, sd);
1349 sd->focus_highlight.cur.target = NULL;
1351 _elm_win_focus_highlight_reconfigure_job_start(sd);
1354 static Evas_Object *
1355 _elm_win_focus_target_get(Evas_Object *obj)
1357 Evas_Object *o = obj;
1361 if (elm_widget_is(o))
1363 if (!elm_widget_highlight_ignore_get(o))
1365 o = elm_widget_parent_get(o);
1367 o = evas_object_smart_parent_get(o);
1371 o = elm_widget_parent_widget_get(o);
1373 o = evas_object_smart_parent_get(o);
1382 _elm_win_focus_target_callbacks_add(Elm_Win_Smart_Data *sd)
1384 Evas_Object *obj = sd->focus_highlight.cur.target;
1387 evas_object_event_callback_add
1388 (obj, EVAS_CALLBACK_MOVE, _elm_win_focus_target_move, sd->obj);
1389 evas_object_event_callback_add
1390 (obj, EVAS_CALLBACK_RESIZE, _elm_win_focus_target_resize, sd->obj);
1391 evas_object_event_callback_add
1392 (obj, EVAS_CALLBACK_DEL, _elm_win_focus_target_del, sd->obj);
1396 _elm_win_focus_target_callbacks_del(Elm_Win_Smart_Data *sd)
1398 Evas_Object *obj = sd->focus_highlight.cur.target;
1400 evas_object_event_callback_del_full
1401 (obj, EVAS_CALLBACK_MOVE, _elm_win_focus_target_move, sd->obj);
1402 evas_object_event_callback_del_full
1403 (obj, EVAS_CALLBACK_RESIZE, _elm_win_focus_target_resize, sd->obj);
1404 evas_object_event_callback_del_full
1405 (obj, EVAS_CALLBACK_DEL, _elm_win_focus_target_del, sd->obj);
1409 _elm_win_object_focus_in(void *data,
1410 Evas *e EINA_UNUSED,
1413 Evas_Object *obj = event_info, *target;
1414 ELM_WIN_DATA_GET(data, sd);
1416 if (sd->focus_highlight.cur.target == obj)
1419 target = _elm_win_focus_target_get(obj);
1420 sd->focus_highlight.cur.target = target;
1421 if (target && elm_widget_highlight_in_theme_get(target))
1422 sd->focus_highlight.cur.in_theme = EINA_TRUE;
1424 _elm_win_focus_target_callbacks_add(sd);
1426 _elm_win_focus_highlight_reconfigure_job_start(sd);
1430 _elm_win_object_focus_out(void *data,
1431 Evas *e EINA_UNUSED,
1432 void *event_info EINA_UNUSED)
1434 ELM_WIN_DATA_GET(data, sd);
1436 if (!sd->focus_highlight.cur.target)
1439 if (!sd->focus_highlight.cur.in_theme)
1440 _elm_win_focus_target_callbacks_del(sd);
1442 sd->focus_highlight.cur.target = NULL;
1443 sd->focus_highlight.cur.in_theme = EINA_FALSE;
1445 _elm_win_focus_highlight_reconfigure_job_start(sd);
1449 _elm_win_focus_highlight_shutdown(Elm_Win_Smart_Data *sd)
1451 _elm_win_focus_highlight_reconfigure_job_stop(sd);
1452 if (sd->focus_highlight.cur.target)
1454 elm_widget_signal_emit(sd->focus_highlight.cur.target,
1455 "elm,action,focus_highlight,hide", "elm");
1456 _elm_win_focus_target_callbacks_del(sd);
1457 sd->focus_highlight.cur.target = NULL;
1459 ELM_SAFE_FREE(sd->focus_highlight.fobj, evas_object_del);
1461 evas_event_callback_del_full
1462 (sd->evas, EVAS_CALLBACK_CANVAS_OBJECT_FOCUS_IN,
1463 _elm_win_object_focus_in, sd->obj);
1464 evas_event_callback_del_full
1465 (sd->evas, EVAS_CALLBACK_CANVAS_OBJECT_FOCUS_OUT,
1466 _elm_win_object_focus_out, sd->obj);
1470 _elm_win_on_img_obj_del(void *data,
1471 Evas *e EINA_UNUSED,
1472 Evas_Object *obj EINA_UNUSED,
1473 void *event_info EINA_UNUSED)
1475 ELM_WIN_DATA_GET(data, sd);
1480 _elm_win_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
1482 Elm_Win_Smart_Data *sd = _pd;
1484 evas_object_event_callback_del_full(sd->layout,
1485 EVAS_CALLBACK_CHANGED_SIZE_HINTS,
1486 _elm_win_on_resize_obj_changed_size_hints,
1488 evas_object_del(sd->box);
1489 evas_object_del(sd->layout);
1491 /* NB: child deletion handled by parent's smart del */
1493 if ((trap) && (trap->del))
1494 trap->del(sd->trap_data, obj);
1498 evas_object_event_callback_del_full
1499 (sd->parent, EVAS_CALLBACK_DEL, _elm_win_on_parent_del, obj);
1503 if (sd->autodel_clear) *(sd->autodel_clear) = -1;
1505 _elm_win_list = eina_list_remove(_elm_win_list, obj);
1507 _elm_win_state_eval_queue();
1511 ecore_evas_callback_delete_request_set(sd->ee, NULL);
1512 ecore_evas_callback_resize_set(sd->ee, NULL);
1515 ecore_job_del(sd->deferred_resize_job);
1516 ecore_job_del(sd->deferred_child_eval_job);
1517 eina_stringshare_del(sd->shot.info);
1518 ecore_timer_del(sd->shot.timer);
1520 #ifdef HAVE_ELEMENTARY_X
1521 ecore_event_handler_del(sd->x.client_message_handler);
1522 ecore_event_handler_del(sd->x.property_handler);
1527 evas_object_event_callback_del_full
1528 (sd->img_obj, EVAS_CALLBACK_DEL, _elm_win_on_img_obj_del, obj);
1535 ecore_job_add(_deferred_ecore_evas_free, sd->ee);
1536 _elm_win_deferred_free++;
1540 _elm_win_focus_highlight_shutdown(sd);
1541 eina_stringshare_del(sd->focus_highlight.style);
1543 eina_stringshare_del(sd->title);
1544 eina_stringshare_del(sd->icon_name);
1545 eina_stringshare_del(sd->role);
1546 evas_object_del(sd->icon);
1547 evas_object_del(sd->main_menu);
1549 _elm_win_profile_del(sd);
1550 _elm_win_available_profiles_del(sd);
1552 /* Don't let callback in the air that point to sd */
1553 ecore_evas_callback_delete_request_set(sd->ee, NULL);
1554 ecore_evas_callback_resize_set(sd->ee, NULL);
1555 ecore_evas_callback_mouse_in_set(sd->ee, NULL);
1556 ecore_evas_callback_focus_in_set(sd->ee, NULL);
1557 ecore_evas_callback_focus_out_set(sd->ee, NULL);
1558 ecore_evas_callback_move_set(sd->ee, NULL);
1559 ecore_evas_callback_state_change_set(sd->ee, NULL);
1561 eo_do_super(obj, MY_CLASS, evas_obj_smart_del());
1563 if ((!_elm_win_list) &&
1564 (elm_policy_get(ELM_POLICY_QUIT) == ELM_POLICY_QUIT_LAST_WINDOW_CLOSED))
1566 edje_file_cache_flush();
1567 edje_collection_cache_flush();
1568 evas_image_cache_flush(evas_object_evas_get(obj));
1569 evas_font_cache_flush(evas_object_evas_get(obj));
1575 _elm_win_obj_intercept_show(void *data,
1578 ELM_WIN_DATA_GET(data, sd);
1580 // this is called to make sure all smart containers have calculated their
1581 // sizes BEFORE we show the window to make sure it initially appears at
1582 // our desired size (ie min size is known first)
1583 evas_smart_objects_calculate(evas_object_evas_get(obj));
1586 evas_object_show(sd->frame_obj);
1590 evas_object_show(sd->img_obj);
1592 if (sd->pointer.obj)
1594 ecore_evas_show(sd->pointer.ee);
1595 evas_object_show(sd->pointer.obj);
1597 evas_object_show(obj);
1601 _elm_win_smart_move(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1603 Evas_Coord x = va_arg(*list, Evas_Coord);
1604 Evas_Coord y = va_arg(*list, Evas_Coord);
1605 Elm_Win_Smart_Data *sd = _pd;
1609 if ((x != sd->screen.x) || (y != sd->screen.y))
1613 evas_object_smart_callback_call(obj, SIG_MOVED, NULL);
1619 TRAP(sd, move, x, y);
1620 if (!ecore_evas_override_get(sd->ee)) return;
1623 eo_do_super(obj, MY_CLASS, evas_obj_smart_move(x, y));
1625 if (ecore_evas_override_get(sd->ee))
1629 evas_object_smart_callback_call(obj, SIG_MOVED, NULL);
1633 /* FIXME: We should update ecore_wl_window_location here !! */
1645 _elm_win_smart_resize(Eo *obj, void *_pd, va_list *list)
1647 Evas_Coord w = va_arg(*list, Evas_Coord);
1648 Evas_Coord h = va_arg(*list, Evas_Coord);
1650 Elm_Win_Smart_Data *sd = _pd;
1652 eo_do_super(obj, MY_CLASS, evas_obj_smart_resize(w, h));
1660 ecore_evas_screen_geometry_get(sd->ee, NULL, NULL, &sw, &sh);
1667 evas_object_image_size_set(sd->img_obj, w, h);
1670 TRAP(sd, resize, w, h);
1674 _elm_win_delete_request(Ecore_Evas *ee)
1676 Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
1679 EINA_SAFETY_ON_NULL_RETURN(sd);
1683 int autodel = sd->autodel;
1684 sd->autodel_clear = &autodel;
1685 evas_object_ref(obj);
1686 evas_object_smart_callback_call(obj, SIG_DELETE_REQUEST, NULL);
1687 // FIXME: if above callback deletes - then the below will be invalid
1688 if (autodel) evas_object_del(obj);
1689 else sd->autodel_clear = NULL;
1690 evas_object_unref(obj);
1694 _elm_ee_xwin_get(const Ecore_Evas *ee)
1696 #ifdef HAVE_ELEMENTARY_X
1697 const char *engine_name;
1700 engine_name = ecore_evas_engine_name_get(ee);
1701 if (EINA_UNLIKELY(!engine_name)) return 0;
1703 if (!strcmp(engine_name, ELM_SOFTWARE_X11))
1705 return ecore_evas_software_x11_window_get(ee);
1707 else if (!strcmp(engine_name, ELM_OPENGL_X11))
1709 return ecore_evas_gl_x11_window_get(ee);
1711 else if (!strcmp(engine_name, ELM_SOFTWARE_WIN32))
1713 return (long)ecore_evas_win32_window_get(ee);
1719 #ifdef HAVE_ELEMENTARY_X
1721 _elm_win_xwindow_get(Elm_Win_Smart_Data *sd)
1723 sd->x.xwin = _elm_ee_xwin_get(sd->ee);
1728 _elm_ee_wlwin_get(const Ecore_Evas *ee)
1730 #ifdef HAVE_ELEMENTARY_WAYLAND
1731 const char *engine_name;
1733 if (!ee) return NULL;
1735 engine_name = ecore_evas_engine_name_get(ee);
1736 if (EINA_UNLIKELY(!engine_name)) return NULL;
1738 if ((!strcmp(engine_name, ELM_WAYLAND_SHM)) ||
1739 (!strcmp(engine_name, ELM_WAYLAND_EGL)))
1741 return ecore_evas_wayland_window_get(ee);
1749 #ifdef HAVE_ELEMENTARY_WAYLAND
1751 _elm_win_wlwindow_get(Elm_Win_Smart_Data *sd)
1753 sd->wl.win = _elm_ee_wlwin_get(sd->ee);
1757 #ifdef HAVE_ELEMENTARY_X
1759 _elm_win_xwin_update(Elm_Win_Smart_Data *sd)
1763 _elm_win_xwindow_get(sd);
1766 ELM_WIN_DATA_GET(sd->parent, sdp);
1770 ecore_x_icccm_transient_for_set(sd->x.xwin, sdp->x.xwin);
1774 if (!sd->x.xwin) return; /* nothing more to do */
1777 if (!s) s = _elm_appname;
1779 if (sd->icon_name) s = sd->icon_name;
1780 ecore_x_icccm_icon_name_set(sd->x.xwin, s);
1781 ecore_x_netwm_icon_name_set(sd->x.xwin, s);
1784 if (s) ecore_x_icccm_window_role_set(sd->x.xwin, s);
1791 data = evas_object_image_data_get(sd->icon, EINA_FALSE);
1795 int w = 0, h = 0, stride, x, y;
1799 evas_object_image_size_get(sd->icon, &w, &h);
1800 stride = evas_object_image_stride_get(sd->icon);
1801 if ((w > 0) && (h > 0) &&
1802 (stride >= (int)(w * sizeof(unsigned int))))
1806 ic.data = malloc(w * h * sizeof(unsigned int));
1810 p = (unsigned char *)data;
1811 p2 = (unsigned int *)ic.data;
1812 for (y = 0; y < h; y++)
1814 for (x = 0; x < w; x++)
1816 *p2 = *((unsigned int *)p);
1817 p += sizeof(unsigned int);
1820 p += (stride - (w * sizeof(unsigned int)));
1822 ecore_x_netwm_icons_set(sd->x.xwin, &ic, 1);
1826 evas_object_image_data_set(sd->icon, data);
1833 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_NORMAL);
1836 case ELM_WIN_DIALOG_BASIC:
1837 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DIALOG);
1840 case ELM_WIN_DESKTOP:
1841 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DESKTOP);
1845 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DOCK);
1848 case ELM_WIN_TOOLBAR:
1849 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_TOOLBAR);
1853 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_MENU);
1856 case ELM_WIN_UTILITY:
1857 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_UTILITY);
1860 case ELM_WIN_SPLASH:
1861 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_SPLASH);
1864 case ELM_WIN_DROPDOWN_MENU:
1865 ecore_x_netwm_window_type_set
1866 (sd->x.xwin, ECORE_X_WINDOW_TYPE_DROPDOWN_MENU);
1869 case ELM_WIN_POPUP_MENU:
1870 ecore_x_netwm_window_type_set
1871 (sd->x.xwin, ECORE_X_WINDOW_TYPE_POPUP_MENU);
1874 case ELM_WIN_TOOLTIP:
1875 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_TOOLTIP);
1878 case ELM_WIN_NOTIFICATION:
1879 ecore_x_netwm_window_type_set
1880 (sd->x.xwin, ECORE_X_WINDOW_TYPE_NOTIFICATION);
1884 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_COMBO);
1888 ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DND);
1894 ecore_x_e_virtual_keyboard_state_set
1895 (sd->x.xwin, (Ecore_X_Virtual_Keyboard_State)sd->kbdmode);
1896 if (sd->indmode == ELM_WIN_INDICATOR_SHOW)
1897 ecore_x_e_illume_indicator_state_set
1898 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_STATE_ON);
1899 else if (sd->indmode == ELM_WIN_INDICATOR_HIDE)
1900 ecore_x_e_illume_indicator_state_set
1901 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_STATE_OFF);
1909 * Resize the window according to window layout's min and weight.
1910 * If the window layout's weight is 0.0, the window max is limited to layout's
1913 * This is called when the window layout's weight hint is changed or when the
1914 * window is rotated.
1916 * @param obj window object
1919 _elm_win_resize_objects_eval(Evas_Object *obj)
1921 ELM_WIN_DATA_GET(obj, sd);
1922 Evas_Coord w, h, minw, minh, maxw, maxh;
1925 evas_object_size_hint_min_get(sd->layout, &minw, &minh);
1926 if (minw < 1) minw = 1;
1927 if (minh < 1) minh = 1;
1929 evas_object_size_hint_weight_get(sd->layout, &wx, &wy);
1930 if (!wx) maxw = minw;
1932 if (!wy) maxh = minh;
1935 evas_object_size_hint_min_set(obj, minw, minh);
1936 evas_object_size_hint_max_set(obj, maxw, maxh);
1937 evas_object_geometry_get(obj, NULL, NULL, &w, &h);
1938 if (w < minw) w = minw;
1939 if (h < minh) h = minh;
1940 if (w > maxw) w = maxw;
1941 if (h > maxh) h = maxh;
1942 evas_object_move(obj, 0, 0);
1943 evas_object_resize(obj, w, h);
1947 _elm_win_on_resize_obj_changed_size_hints(void *data,
1948 Evas *e EINA_UNUSED,
1949 Evas_Object *obj EINA_UNUSED,
1950 void *event_info EINA_UNUSED)
1952 _elm_win_resize_objects_eval(data);
1956 _elm_win_shutdown(void)
1958 while (_elm_win_list) evas_object_del(_elm_win_list->data);
1959 ELM_SAFE_FREE(_elm_win_state_eval_job, ecore_job_del);
1963 _elm_win_rescale(Elm_Theme *th,
1964 Eina_Bool use_theme)
1971 EINA_LIST_FOREACH(_elm_win_list, l, obj)
1972 elm_widget_theme(obj);
1976 EINA_LIST_FOREACH(_elm_win_list, l, obj)
1977 elm_widget_theme_specific(obj, th, EINA_FALSE);
1982 _elm_win_access(Eina_Bool is_access)
1989 EINA_LIST_FOREACH(_elm_win_list, l, obj)
1991 elm_widget_access(obj, is_access);
1993 /* floating orphan object. if there are A, B, C objects and user does
1994 as below, then there would be floating orphan objects.
1996 1. elm_object_content_set(layout, A);
1997 2. elm_object_content_set(layout, B);
1998 3. elm_object_content_set(layout, C);
2000 now, the object A and B are floating orphan objects */
2005 fobj = evas_object_below_get(fobj);
2008 if (elm_widget_is(fobj) && !elm_widget_parent_get(fobj))
2010 elm_widget_access(fobj, is_access);
2016 evas = evas_object_evas_get(obj);
2017 if (evas) _elm_access_object_highlight_disable(evas);
2023 _elm_win_translate(void)
2028 EINA_LIST_FOREACH(_elm_win_list, l, obj)
2029 elm_widget_translate(obj);
2032 #ifdef HAVE_ELEMENTARY_X
2034 _elm_win_client_message(void *data,
2035 int type EINA_UNUSED,
2038 ELM_WIN_DATA_GET(data, sd);
2039 Ecore_X_Event_Client_Message *e = event;
2041 if (e->format != 32) return ECORE_CALLBACK_PASS_ON;
2042 if (e->message_type == ECORE_X_ATOM_E_COMP_FLUSH)
2044 if ((unsigned int)e->data.l[0] == sd->x.xwin)
2046 Evas *evas = evas_object_evas_get(sd->obj);
2049 edje_file_cache_flush();
2050 edje_collection_cache_flush();
2051 evas_image_cache_flush(evas);
2052 evas_font_cache_flush(evas);
2056 else if (e->message_type == ECORE_X_ATOM_E_COMP_DUMP)
2058 if ((unsigned int)e->data.l[0] == sd->x.xwin)
2060 Evas *evas = evas_object_evas_get(sd->obj);
2063 edje_file_cache_flush();
2064 edje_collection_cache_flush();
2065 evas_image_cache_flush(evas);
2066 evas_font_cache_flush(evas);
2067 evas_render_dump(evas);
2071 else if (e->message_type == ECORE_X_ATOM_E_ILLUME_ACCESS_CONTROL)
2073 if ((unsigned int)e->data.l[0] == sd->x.xwin)
2075 if ((unsigned int)e->data.l[1] ==
2076 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_NEXT)
2078 // XXX: call right access func
2080 else if ((unsigned int)e->data.l[1] ==
2081 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_PREV)
2083 // XXX: call right access func
2085 else if ((unsigned int)e->data.l[1] ==
2086 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_ACTIVATE)
2088 _elm_access_highlight_object_activate
2089 (sd->obj, ELM_ACTIVATE_DEFAULT);
2091 else if ((unsigned int)e->data.l[1] ==
2092 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_READ)
2094 /* there would be better way to read highlight object */
2096 evas = evas_object_evas_get(sd->obj);
2097 if (!evas) return ECORE_CALLBACK_PASS_ON;
2099 _elm_access_mouse_event_enabled_set(EINA_TRUE);
2101 evas_event_feed_mouse_in(evas, 0, NULL);
2102 evas_event_feed_mouse_move
2103 (evas, e->data.l[2], e->data.l[3], 0, NULL);
2105 _elm_access_mouse_event_enabled_set(EINA_FALSE);
2107 else if ((unsigned int)e->data.l[1] ==
2108 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_READ_NEXT)
2110 _elm_access_highlight_cycle(sd->obj, ELM_FOCUS_NEXT);
2112 else if ((unsigned int)e->data.l[1] ==
2113 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_READ_PREV)
2115 _elm_access_highlight_cycle(sd->obj, ELM_FOCUS_PREVIOUS);
2117 else if ((unsigned int)e->data.l[1] ==
2118 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_UP)
2120 _elm_access_highlight_object_activate
2121 (sd->obj, ELM_ACTIVATE_UP);
2123 else if ((unsigned int)e->data.l[1] ==
2124 ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_DOWN)
2126 _elm_access_highlight_object_activate
2127 (sd->obj, ELM_ACTIVATE_DOWN);
2131 return ECORE_CALLBACK_PASS_ON;
2135 _elm_win_property_change(void *data,
2136 int type EINA_UNUSED,
2139 ELM_WIN_DATA_GET(data, sd);
2140 Ecore_X_Event_Window_Property *e = event;
2142 if (e->atom == ECORE_X_ATOM_E_ILLUME_INDICATOR_STATE)
2144 if (e->win == sd->x.xwin)
2146 sd->indmode = (Elm_Win_Indicator_Mode)ecore_x_e_illume_indicator_state_get(e->win);
2147 evas_object_smart_callback_call(sd->obj, SIG_INDICATOR_PROP_CHANGED, NULL);
2150 return ECORE_CALLBACK_PASS_ON;
2155 _elm_win_focus_highlight_hide(void *data EINA_UNUSED,
2157 const char *emission EINA_UNUSED,
2158 const char *source EINA_UNUSED)
2160 evas_object_hide(obj);
2164 _elm_win_focus_highlight_anim_end(void *data,
2166 const char *emission EINA_UNUSED,
2167 const char *source EINA_UNUSED)
2169 ELM_WIN_DATA_GET(data, sd);
2171 _elm_win_focus_highlight_simple_setup(sd, obj);
2175 _elm_win_focus_highlight_init(Elm_Win_Smart_Data *sd)
2177 evas_event_callback_add(sd->evas, EVAS_CALLBACK_CANVAS_OBJECT_FOCUS_IN,
2178 _elm_win_object_focus_in, sd->obj);
2179 evas_event_callback_add(sd->evas,
2180 EVAS_CALLBACK_CANVAS_OBJECT_FOCUS_OUT,
2181 _elm_win_object_focus_out, sd->obj);
2183 sd->focus_highlight.cur.target = evas_focus_get(sd->evas);
2184 sd->focus_highlight.fobj = edje_object_add(sd->evas);
2185 sd->focus_highlight.theme_changed = EINA_TRUE;
2187 edje_object_signal_callback_add(sd->focus_highlight.fobj,
2188 "elm,action,focus,hide,end", "*",
2189 _elm_win_focus_highlight_hide, NULL);
2190 edje_object_signal_callback_add(sd->focus_highlight.fobj,
2191 "elm,action,focus,anim,end", "*",
2192 _elm_win_focus_highlight_anim_end, sd->obj);
2193 _elm_win_focus_highlight_reconfigure_job_start(sd);
2197 _elm_win_frame_cb_move_start(void *data,
2198 Evas_Object *obj EINA_UNUSED,
2199 const char *sig EINA_UNUSED,
2202 ELM_WIN_DATA_GET(data, sd);
2206 #ifdef HAVE_ELEMENTARY_WAYLAND
2207 if (!strcmp(source, "elm"))
2208 ecore_wl_window_cursor_from_name_set(sd->wl.win, ELM_CURSOR_HAND1);
2210 ecore_wl_window_cursor_default_restore(sd->wl.win);
2215 /* FIXME: Change mouse pointer */
2217 /* NB: Wayland handles moving surfaces by itself so we cannot
2218 * specify a specific x/y we want. Instead, we will pass in the
2219 * existing x/y values so they can be recorded as 'previous'
2220 * position. The new position will get updated automatically when
2221 * the move is finished */
2223 ecore_evas_wayland_move(sd->ee, sd->screen.x, sd->screen.y);
2227 _elm_win_frame_cb_move_stop(void *data,
2228 Evas_Object *obj EINA_UNUSED,
2229 const char *sig EINA_UNUSED,
2230 const char *source EINA_UNUSED)
2232 ELM_WIN_DATA_GET(data, sd);
2236 #ifdef HAVE_ELEMENTARY_WAYLAND
2237 ecore_wl_window_cursor_default_restore(sd->wl.win);
2241 #ifdef HAVE_ELEMENTARY_WAYLAND
2248 static struct _resize_info _border_side[4] =
2250 { ELM_CURSOR_TOP_SIDE, 1 },
2251 { ELM_CURSOR_LEFT_SIDE, 4 },
2252 { ELM_CURSOR_BOTTOM_SIDE, 2 },
2253 { ELM_CURSOR_RIGHT_SIDE, 8 },
2256 static struct _resize_info _border_corner[4] =
2258 { ELM_CURSOR_TOP_LEFT_CORNER, 5 },
2259 { ELM_CURSOR_BOTTOM_LEFT_CORNER, 6 },
2260 { ELM_CURSOR_BOTTOM_RIGHT_CORNER, 10 },
2261 { ELM_CURSOR_TOP_RIGHT_CORNER, 9 },
2266 _elm_win_frame_obj_update(Elm_Win_Smart_Data *sd)
2272 evas_object_geometry_get(sd->frame_obj, &fx, &fy, &fw, &fh);
2273 evas_object_geometry_get(sd->client_obj, &ox, &oy, &ow, &oh);
2274 evas_object_geometry_get(sd->spacer_obj, &sx, &sy, &sw, &sh);
2276 evas_output_framespace_get(sd->evas, &x, &y, &w, &h);
2278 if ((x != (ox - fx)) || (y != (oy - fy)) ||
2279 (w != (fw - ow)) || (h != (fh - oh)))
2281 evas_output_framespace_set(sd->evas, (ox - fx), (oy - fy),
2282 (fw - ow), (fh - oh));
2285 #ifdef HAVE_ELEMENTARY_WAYLAND
2286 ecore_wl_window_opaque_region_set(sd->wl.win, -fx, -(fy - sy), sw, sh);
2291 _elm_win_frame_obj_move(void *data,
2292 Evas *e EINA_UNUSED,
2293 Evas_Object *obj EINA_UNUSED,
2294 void *event_info EINA_UNUSED)
2296 Elm_Win_Smart_Data *sd;
2298 if (!(sd = data)) return;
2299 if (!sd->client_obj) return;
2301 _elm_win_frame_obj_update(sd);
2305 _elm_win_frame_obj_resize(void *data,
2306 Evas *e EINA_UNUSED,
2307 Evas_Object *obj EINA_UNUSED,
2308 void *event_info EINA_UNUSED)
2310 Elm_Win_Smart_Data *sd;
2312 if (!(sd = data)) return;
2313 if (!sd->client_obj) return;
2315 _elm_win_frame_obj_update(sd);
2319 _elm_win_frame_cb_resize_show(void *data,
2320 Evas_Object *obj EINA_UNUSED,
2321 const char *sig EINA_UNUSED,
2324 ELM_WIN_DATA_GET(data, sd);
2327 if (sd->resizing) return;
2329 #ifdef HAVE_ELEMENTARY_WAYLAND
2332 if (!strcmp(source, "elm.event.resize.t"))
2333 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2334 _border_side[(0 + i) % 4].name);
2335 else if (!strcmp(source, "elm.event.resize.b"))
2336 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2337 _border_side[(2 + i) % 4].name);
2338 else if (!strcmp(source, "elm.event.resize.l"))
2339 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2340 _border_side[(1 + i) % 4].name);
2341 else if (!strcmp(source, "elm.event.resize.r"))
2342 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2343 _border_side[(3 + i) % 4].name);
2344 else if (!strcmp(source, "elm.event.resize.tl"))
2345 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2346 _border_corner[(0 + i) % 4].name);
2347 else if (!strcmp(source, "elm.event.resize.tr"))
2348 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2349 _border_corner[(3 + i) % 4].name);
2350 else if (!strcmp(source, "elm.event.resize.bl"))
2351 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2352 _border_corner[(1 + i) % 4].name);
2353 else if (!strcmp(source, "elm.event.resize.br"))
2354 ecore_wl_window_cursor_from_name_set(sd->wl.win,
2355 _border_corner[(2 + i) % 4].name);
2357 ecore_wl_window_cursor_default_restore(sd->wl.win);
2364 _elm_win_frame_cb_resize_hide(void *data,
2365 Evas_Object *obj EINA_UNUSED,
2366 const char *sig EINA_UNUSED,
2367 const char *source EINA_UNUSED)
2369 ELM_WIN_DATA_GET(data, sd);
2372 if (sd->resizing) return;
2374 #ifdef HAVE_ELEMENTARY_WAYLAND
2375 ecore_wl_window_cursor_default_restore(sd->wl.win);
2380 _elm_win_frame_cb_resize_start(void *data,
2381 Evas_Object *obj EINA_UNUSED,
2382 const char *sig EINA_UNUSED,
2385 #ifdef HAVE_ELEMENTARY_WAYLAND
2386 ELM_WIN_DATA_GET(data, sd);
2390 if (sd->resizing) return;
2392 sd->resizing = EINA_TRUE;
2394 if (!strcmp(source, "elm.event.resize.t"))
2395 sd->resize_location = _border_side[(0 + i) % 4].location;
2396 else if (!strcmp(source, "elm.event.resize.b"))
2397 sd->resize_location = _border_side[(2 + i) % 4].location;
2398 else if (!strcmp(source, "elm.event.resize.l"))
2399 sd->resize_location = _border_side[(1 + i) % 4].location;
2400 else if (!strcmp(source, "elm.event.resize.r"))
2401 sd->resize_location = _border_side[(3 + i) % 4].location;
2402 else if (!strcmp(source, "elm.event.resize.tl"))
2403 sd->resize_location = _border_corner[(0 + i) % 4].location;
2404 else if (!strcmp(source, "elm.event.resize.tr"))
2405 sd->resize_location = _border_corner[(3 + i) % 4].location;
2406 else if (!strcmp(source, "elm.event.resize.bl"))
2407 sd->resize_location = _border_corner[(1 + i) % 4].location;
2408 else if (!strcmp(source, "elm.event.resize.br"))
2409 sd->resize_location = _border_corner[(2 + i) % 4].location;
2411 sd->resize_location = 0;
2413 if (sd->resize_location > 0)
2414 ecore_evas_wayland_resize(sd->ee, sd->resize_location);
2422 _elm_win_frame_cb_minimize(void *data,
2423 Evas_Object *obj EINA_UNUSED,
2424 const char *sig EINA_UNUSED,
2425 const char *source EINA_UNUSED)
2427 ELM_WIN_DATA_GET(data, sd);
2430 // sd->iconified = EINA_TRUE;
2431 TRAP(sd, iconified_set, EINA_TRUE);
2435 _elm_win_frame_maximized_state_update(Elm_Win_Smart_Data *sd, Eina_Bool maximized)
2437 const char *emission;
2440 emission = "elm,state,maximized";
2442 emission = "elm,state,unmaximized";
2444 edje_object_signal_emit(sd->frame_obj, emission, "elm");
2445 edje_object_message_signal_process(sd->frame_obj);
2446 evas_object_smart_calculate(sd->frame_obj);
2448 _elm_win_frame_obj_update(sd);
2452 _elm_win_frame_cb_maximize(void *data,
2453 Evas_Object *obj EINA_UNUSED,
2454 const char *sig EINA_UNUSED,
2455 const char *source EINA_UNUSED)
2458 ELM_WIN_DATA_GET(data, sd);
2461 if (sd->maximized) value = EINA_FALSE;
2462 else value = EINA_TRUE;
2464 _elm_win_frame_maximized_state_update(sd, value);
2466 TRAP(sd, maximized_set, value);
2470 _elm_win_frame_cb_close(void *data,
2471 Evas_Object *obj EINA_UNUSED,
2472 const char *sig EINA_UNUSED,
2473 const char *source EINA_UNUSED)
2475 ELM_WIN_DATA_GET(data, sd);
2478 /* FIXME: After the current freeze, this should be handled differently.
2480 * Ideally, we would want to mimic the X11 backend and use something
2481 * like ECORE_WL_EVENT_WINDOW_DELETE and handle the delete_request
2482 * inside of ecore_evas. That would be the 'proper' way, but since we are
2483 * in a freeze right now, I cannot add a new event value, or a new
2484 * event structure to ecore_wayland.
2486 * So yes, this is a temporary 'stop-gap' solution which will be fixed
2487 * when the freeze is over, but it does fix a trac bug for now, and in a
2488 * way which does not break API or the freeze. - dh
2495 int autodel = sd->autodel;
2496 sd->autodel_clear = &autodel;
2497 evas_object_ref(win);
2498 evas_object_smart_callback_call(win, SIG_DELETE_REQUEST, NULL);
2499 // FIXME: if above callback deletes - then the below will be invalid
2500 if (autodel) evas_object_del(win);
2501 else sd->autodel_clear = NULL;
2502 evas_object_unref(win);
2506 _elm_win_frame_add(Elm_Win_Smart_Data *sd,
2509 Evas_Object *obj = sd->obj;
2513 sd->frame_obj = edje_object_add(sd->evas);
2514 layer = evas_object_layer_get(obj);
2515 evas_object_layer_set(sd->frame_obj, layer + 1);
2516 if (!elm_widget_theme_object_set
2517 (sd->obj, sd->frame_obj, "border", "base", style))
2519 ELM_SAFE_FREE(sd->frame_obj, evas_object_del);
2523 sd->spacer_obj = evas_object_rectangle_add(sd->evas);
2524 evas_object_color_set(sd->spacer_obj, 0, 0, 0, 0);
2525 evas_object_repeat_events_set(sd->spacer_obj, EINA_TRUE);
2526 edje_object_part_swallow(sd->frame_obj, "elm.swallow.frame_spacer",
2529 sd->client_obj = evas_object_rectangle_add(sd->evas);
2530 evas_object_color_set(sd->client_obj, 0, 0, 0, 0);
2531 /* NB: Tried pass_events here, but that fails to send events */
2532 evas_object_repeat_events_set(sd->client_obj, EINA_TRUE);
2533 edje_object_part_swallow(sd->frame_obj, "elm.swallow.client",
2536 evas_object_is_frame_object_set(sd->frame_obj, EINA_TRUE);
2538 evas_object_event_callback_add
2539 (sd->frame_obj, EVAS_CALLBACK_MOVE, _elm_win_frame_obj_move, sd);
2540 evas_object_event_callback_add
2541 (sd->frame_obj, EVAS_CALLBACK_RESIZE, _elm_win_frame_obj_resize, sd);
2543 /* NB: Do NOT remove these calls !! Needed to calculate proper
2544 * framespace on inital show of the window */
2545 edje_object_size_min_calc(sd->frame_obj, &mw, &mh);
2546 evas_object_move(sd->frame_obj, 0, 0);
2547 evas_object_resize(sd->frame_obj, mw, mh);
2548 evas_object_smart_calculate(sd->frame_obj);
2550 edje_object_signal_callback_add
2551 (sd->frame_obj, "elm,action,move,start", "elm",
2552 _elm_win_frame_cb_move_start, obj);
2553 edje_object_signal_callback_add
2554 (sd->frame_obj, "elm,action,move,stop", "elm",
2555 _elm_win_frame_cb_move_stop, obj);
2556 edje_object_signal_callback_add
2557 (sd->frame_obj, "elm,action,resize,show", "*",
2558 _elm_win_frame_cb_resize_show, obj);
2559 edje_object_signal_callback_add
2560 (sd->frame_obj, "elm,action,resize,hide", "*",
2561 _elm_win_frame_cb_resize_hide, obj);
2562 edje_object_signal_callback_add
2563 (sd->frame_obj, "elm,action,resize,start", "*",
2564 _elm_win_frame_cb_resize_start, obj);
2565 edje_object_signal_callback_add
2566 (sd->frame_obj, "elm,action,minimize", "elm",
2567 _elm_win_frame_cb_minimize, obj);
2568 edje_object_signal_callback_add
2569 (sd->frame_obj, "elm,action,maximize", "elm",
2570 _elm_win_frame_cb_maximize, obj);
2571 edje_object_signal_callback_add
2572 (sd->frame_obj, "elm,action,close", "elm", _elm_win_frame_cb_close, obj);
2576 edje_object_part_text_escaped_set
2577 (sd->frame_obj, "elm.text.title", sd->title);
2580 ecore_evas_geometry_get(sd->ee, NULL, NULL, &w, &h);
2581 ecore_evas_resize(sd->ee, w, h);
2585 _elm_win_frame_del(Elm_Win_Smart_Data *sd)
2589 ELM_SAFE_FREE(sd->client_obj, evas_object_del);
2593 evas_object_event_callback_del_full
2594 (sd->frame_obj, EVAS_CALLBACK_MOVE, _elm_win_frame_obj_move, sd);
2595 evas_object_event_callback_del_full
2596 (sd->frame_obj, EVAS_CALLBACK_RESIZE, _elm_win_frame_obj_resize, sd);
2598 edje_object_signal_callback_del
2599 (sd->frame_obj, "elm,action,move,start", "elm",
2600 _elm_win_frame_cb_move_start);
2601 edje_object_signal_callback_del
2602 (sd->frame_obj, "elm,action,move,stop", "elm",
2603 _elm_win_frame_cb_move_stop);
2604 edje_object_signal_callback_del
2605 (sd->frame_obj, "elm,action,resize,show", "*",
2606 _elm_win_frame_cb_resize_show);
2607 edje_object_signal_callback_del
2608 (sd->frame_obj, "elm,action,resize,hide", "*",
2609 _elm_win_frame_cb_resize_hide);
2610 edje_object_signal_callback_del
2611 (sd->frame_obj, "elm,action,resize,start", "*",
2612 _elm_win_frame_cb_resize_start);
2613 edje_object_signal_callback_del
2614 (sd->frame_obj, "elm,action,minimize", "elm",
2615 _elm_win_frame_cb_minimize);
2616 edje_object_signal_callback_del
2617 (sd->frame_obj, "elm,action,maximize", "elm",
2618 _elm_win_frame_cb_maximize);
2619 edje_object_signal_callback_del
2620 (sd->frame_obj, "elm,action,close", "elm",
2621 _elm_win_frame_cb_close);
2623 ELM_SAFE_FREE(sd->frame_obj, evas_object_del);
2626 evas_output_framespace_set(sd->evas, 0, 0, 0, 0);
2627 ecore_evas_geometry_get(sd->ee, NULL, NULL, &w, &h);
2628 ecore_evas_resize(sd->ee, w, h);
2633 _debug_key_down(void *data EINA_UNUSED,
2634 Evas *e EINA_UNUSED,
2638 Evas_Event_Key_Down *ev = event_info;
2640 if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD)
2643 if ((strcmp(ev->key, "F12")) ||
2644 (!evas_key_modifier_is_set(ev->modifiers, "Control")))
2647 INF("Tree graph generated.");
2648 elm_object_tree_dot_dump(obj, "./dump.dot");
2654 _win_img_hide(void *data,
2655 Evas *e EINA_UNUSED,
2656 Evas_Object *obj EINA_UNUSED,
2657 void *event_info EINA_UNUSED)
2659 elm_widget_focus_hide_handle(data);
2663 _win_img_mouse_up(void *data,
2664 Evas *e EINA_UNUSED,
2665 Evas_Object *obj EINA_UNUSED,
2668 Evas_Event_Mouse_Up *ev = event_info;
2669 if (!(ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD))
2670 elm_widget_focus_mouse_up_handle(data);
2674 _win_img_focus_in(void *data,
2675 Evas *e EINA_UNUSED,
2676 Evas_Object *obj EINA_UNUSED,
2677 void *event_info EINA_UNUSED)
2679 elm_widget_focus_steal(data);
2683 _win_img_focus_out(void *data,
2684 Evas *e EINA_UNUSED,
2685 Evas_Object *obj EINA_UNUSED,
2686 void *event_info EINA_UNUSED)
2688 elm_widget_focused_object_clear(data);
2692 _win_inlined_image_set(Elm_Win_Smart_Data *sd)
2694 evas_object_image_alpha_set(sd->img_obj, EINA_FALSE);
2695 evas_object_image_filled_set(sd->img_obj, EINA_TRUE);
2697 evas_object_event_callback_add
2698 (sd->img_obj, EVAS_CALLBACK_DEL, _elm_win_on_img_obj_del, sd->obj);
2699 evas_object_event_callback_add
2700 (sd->img_obj, EVAS_CALLBACK_HIDE, _win_img_hide, sd->obj);
2701 evas_object_event_callback_add
2702 (sd->img_obj, EVAS_CALLBACK_MOUSE_UP, _win_img_mouse_up, sd->obj);
2703 evas_object_event_callback_add
2704 (sd->img_obj, EVAS_CALLBACK_FOCUS_IN, _win_img_focus_in, sd->obj);
2705 evas_object_event_callback_add
2706 (sd->img_obj, EVAS_CALLBACK_FOCUS_OUT, _win_img_focus_out, sd->obj);
2710 _elm_win_on_icon_del(void *data,
2711 Evas *e EINA_UNUSED,
2713 void *event_info EINA_UNUSED)
2715 ELM_WIN_DATA_GET(data, sd);
2717 if (sd->icon == obj) sd->icon = NULL;
2721 _elm_win_smart_add(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED)
2723 eo_do_super(obj, MY_CLASS, evas_obj_smart_add());
2725 elm_widget_can_focus_set(obj, EINA_TRUE);
2727 elm_widget_highlight_ignore_set(obj, EINA_TRUE);
2730 #ifdef HAVE_ELEMENTARY_X
2732 _elm_x_io_err(void *data EINA_UNUSED)
2737 EINA_LIST_FOREACH(_elm_win_list, l, obj)
2738 evas_object_smart_callback_call(obj, SIG_IOERR, NULL);
2744 elm_win_add(Evas_Object *parent,
2748 Evas_Object *obj = eo_add_custom(MY_CLASS, parent, elm_obj_win_constructor(name, type));
2754 _elm_win_cb_hide(void *data EINA_UNUSED,
2755 Evas *e EINA_UNUSED,
2756 Evas_Object *obj EINA_UNUSED,
2757 void *event_info EINA_UNUSED)
2759 _elm_win_state_eval_queue();
2763 _elm_win_cb_show(void *data EINA_UNUSED,
2764 Evas *e EINA_UNUSED,
2765 Evas_Object *obj EINA_UNUSED,
2766 void *event_info EINA_UNUSED)
2768 _elm_win_state_eval_queue();
2774 * Recalculate the size of window considering its resize objects' weight and
2775 * min size. If any of its resize objects' weight equals to 0.0, window
2776 * layout's weight will be set to 0.0.
2778 * @param o box object
2779 * @param p box's private data
2780 * @param data window object
2783 _window_layout_stack(Evas_Object *o, Evas_Object_Box_Data *p, void *data)
2787 Evas_Object_Box_Option *opt;
2788 Evas_Coord x, y, w, h;
2790 Evas_Coord minw = -1, minh = -1;
2791 double weight_x = EVAS_HINT_EXPAND;
2792 double weight_y = EVAS_HINT_EXPAND;
2794 EINA_LIST_FOREACH(p->children, l, opt)
2797 evas_object_size_hint_weight_get(child, &wx, &wy);
2798 if (wx == 0.0) weight_x = 0;
2799 if (wy == 0.0) weight_y = 0;
2801 evas_object_size_hint_min_get(child, &w, &h);
2802 if (w > minw) minw = w;
2803 if (h > minh) minh = h;
2806 evas_object_size_hint_min_set(o, minw, minh);
2807 evas_object_geometry_get(o, &x, &y, &w, &h);
2808 if (w < minw) w = minw;
2809 if (h < minh) h = minh;
2810 evas_object_resize(o, w, h);
2812 EINA_LIST_FOREACH(p->children, l, opt)
2815 evas_object_move(child, x, y);
2816 evas_object_resize(child, w, h);
2819 ELM_WIN_DATA_GET(data, sd);
2820 evas_object_size_hint_weight_set(sd->layout, weight_x, weight_y);
2821 evas_object_smart_changed(sd->layout);
2825 _win_constructor(Eo *obj, void *_pd, va_list *list)
2827 Elm_Win_Smart_Data *sd = _pd;
2828 sd->obj = obj; // in ctor
2830 const char *name = va_arg(*list, const char *);
2831 Elm_Win_Type type = va_arg(*list, Elm_Win_Type);
2832 Evas_Object *parent;
2835 const char *fontpath, *fallback = NULL;
2837 Elm_Win_Smart_Data tmp_sd;
2839 eo_do(obj, eo_parent_get(&parent));
2841 /* just to store some data while trying out to create a canvas */
2842 memset(&tmp_sd, 0, sizeof(Elm_Win_Smart_Data));
2844 #define FALLBACK_TRY(engine) \
2846 CRI(engine " engine creation failed. Trying default."); \
2848 #define FALLBACK_STORE(engine) \
2851 CRI(engine "Fallback to %s successful.", engine); \
2852 fallback = engine; \
2857 case ELM_WIN_INLINED_IMAGE:
2860 e = evas_object_evas_get(parent);
2865 ee = ecore_evas_ecore_evas_get(e);
2868 tmp_sd.img_obj = ecore_evas_object_image_new(ee);
2869 if (!tmp_sd.img_obj) break;
2871 tmp_sd.ee = ecore_evas_object_ecore_evas_get(tmp_sd.img_obj);
2874 ELM_SAFE_FREE(tmp_sd.img_obj, evas_object_del);
2879 case ELM_WIN_SOCKET_IMAGE:
2880 tmp_sd.ee = ecore_evas_extn_socket_new(1, 1);
2884 if (ENGINE_COMPARE(ELM_SOFTWARE_X11))
2886 tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2887 FALLBACK_TRY("Software X11");
2890 tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2891 FALLBACK_STORE("Software FB");
2894 else if (ENGINE_COMPARE(ELM_SOFTWARE_FB))
2896 tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2897 FALLBACK_TRY("Software FB");
2900 tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2901 FALLBACK_STORE("Software X11");
2904 else if (ENGINE_COMPARE(ELM_OPENGL_X11))
2909 if (_elm_config->vsync)
2911 opt[opt_i] = ECORE_EVAS_GL_X11_OPT_VSYNC;
2918 tmp_sd.ee = ecore_evas_gl_x11_options_new
2919 (NULL, 0, 0, 0, 1, 1, opt);
2921 tmp_sd.ee = ecore_evas_gl_x11_new(NULL, 0, 0, 0, 1, 1);
2922 FALLBACK_TRY("OpenGL");
2925 tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2926 FALLBACK_STORE("Software X11");
2929 tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2930 FALLBACK_STORE("Software FB");
2934 else if (ENGINE_COMPARE(ELM_SOFTWARE_WIN32))
2936 tmp_sd.ee = ecore_evas_software_gdi_new(NULL, 0, 0, 1, 1);
2937 FALLBACK_TRY("Software Win32");
2939 else if (ENGINE_COMPARE(ELM_SOFTWARE_PSL1GHT))
2941 tmp_sd.ee = ecore_evas_psl1ght_new(NULL, 1, 1);
2942 FALLBACK_TRY("PSL1GHT");
2944 else if (ENGINE_COMPARE(ELM_SOFTWARE_SDL))
2946 tmp_sd.ee = ecore_evas_sdl_new(NULL, 0, 0, 0, 0, 0, 1);
2947 FALLBACK_TRY("Software SDL");
2950 tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2951 FALLBACK_STORE("Software X11");
2954 tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2955 FALLBACK_STORE("Software FB");
2959 else if (ENGINE_COMPARE(ELM_SOFTWARE_16_SDL))
2961 tmp_sd.ee = ecore_evas_sdl16_new(NULL, 0, 0, 0, 0, 0, 1);
2962 FALLBACK_TRY("Software-16-SDL");
2965 tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2966 FALLBACK_STORE("Software X11");
2969 tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2970 FALLBACK_STORE("Software FB");
2974 else if (ENGINE_COMPARE(ELM_OPENGL_SDL))
2976 tmp_sd.ee = ecore_evas_gl_sdl_new(NULL, 1, 1, 0, 0);
2977 FALLBACK_TRY("OpenGL SDL");
2980 tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2981 FALLBACK_STORE("Software X11");
2984 tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2985 FALLBACK_STORE("Software FB");
2989 else if (ENGINE_COMPARE(ELM_OPENGL_COCOA))
2991 tmp_sd.ee = ecore_evas_cocoa_new(NULL, 1, 1, 0, 0);
2992 FALLBACK_TRY("OpenGL Cocoa");
2994 else if (ENGINE_COMPARE(ELM_BUFFER))
2996 tmp_sd.ee = ecore_evas_buffer_new(1, 1);
2998 else if (ENGINE_COMPARE(ELM_EWS))
3000 tmp_sd.ee = ecore_evas_ews_new(0, 0, 1, 1);
3002 else if (ENGINE_COMPARE(ELM_WAYLAND_SHM))
3004 tmp_sd.ee = ecore_evas_wayland_shm_new(NULL, 0, 0, 0, 1, 1, 0);
3006 else if (ENGINE_COMPARE(ELM_WAYLAND_EGL))
3008 tmp_sd.ee = ecore_evas_wayland_egl_new(NULL, 0, 0, 0, 1, 1, 0);
3010 else if (!strncmp(ENGINE_GET(), "shot:", 5))
3012 tmp_sd.ee = ecore_evas_buffer_new(1, 1);
3013 ecore_evas_manual_render_set(tmp_sd.ee, EINA_TRUE);
3014 tmp_sd.shot.info = eina_stringshare_add
3023 ERR("Cannot create window.");
3028 eo_do(obj, eo_parent_set(ecore_evas_get(tmp_sd.ee)));
3029 eo_do_super(obj, MY_CLASS, eo_constructor());
3031 evas_obj_type_set(MY_CLASS_NAME_LEGACY),
3032 evas_obj_smart_callbacks_descriptions_set(_smart_callbacks, NULL));
3034 if (getenv("ELM_FIRST_FRAME"))
3035 evas_event_callback_add(ecore_evas_get(tmp_sd.ee), EVAS_CALLBACK_RENDER_POST,
3036 _elm_win_first_frame_do, getenv("ELM_FIRST_FRAME"));
3038 /* copying possibly altered fields back */
3039 #define SD_CPY(_field) \
3042 sd->_field = tmp_sd._field; \
3050 if ((trap) && (trap->add))
3051 sd->trap_data = trap->add(obj);
3053 /* complementary actions, which depend on final smart data
3055 if (type == ELM_WIN_INLINED_IMAGE)
3056 _win_inlined_image_set(sd);
3058 #ifdef HAVE_ELEMENTARY_X
3059 else if (ENGINE_COMPARE(ELM_SOFTWARE_X11) ||
3060 ENGINE_COMPARE(ELM_SOFTWARE_16_X11) ||
3061 ENGINE_COMPARE(ELM_SOFTWARE_8_X11) ||
3062 ENGINE_COMPARE(ELM_OPENGL_X11))
3064 sd->x.client_message_handler = ecore_event_handler_add
3065 (ECORE_X_EVENT_CLIENT_MESSAGE, _elm_win_client_message, obj);
3066 sd->x.property_handler = ecore_event_handler_add
3067 (ECORE_X_EVENT_WINDOW_PROPERTY, _elm_win_property_change, obj);
3071 else if (!strncmp(ENGINE_GET(), "shot:", 5))
3074 sd->kbdmode = ELM_WIN_KEYBOARD_UNKNOWN;
3075 sd->indmode = ELM_WIN_INDICATOR_UNKNOWN;
3077 #ifdef HAVE_ELEMENTARY_X
3078 _elm_win_xwindow_get(sd);
3081 ecore_x_io_error_handler_set(_elm_x_io_err, NULL);
3085 #ifdef HAVE_ELEMENTARY_WAYLAND
3086 if ((ENGINE_COMPARE(ELM_WAYLAND_SHM)) || (ENGINE_COMPARE(ELM_WAYLAND_EGL)))
3087 _elm_win_wlwindow_get(sd);
3090 if ((_elm_config->bgpixmap)
3091 #ifdef HAVE_ELEMENTARY_X
3093 (((sd->x.xwin) && (!ecore_x_screen_is_composited(0))) ||
3098 TRAP(sd, avoid_damage_set, ECORE_EVAS_AVOID_DAMAGE_EXPOSE);
3099 // bg pixmap done by x - has other issues like can be redrawn by x before it
3100 // is filled/ready by app
3101 // TRAP(sd, avoid_damage_set, ECORE_EVAS_AVOID_DAMAGE_BUILT_IN);
3104 sd->parent = parent;
3107 evas_object_event_callback_add
3108 (sd->parent, EVAS_CALLBACK_DEL, _elm_win_on_parent_del, obj);
3110 sd->evas = ecore_evas_get(sd->ee);
3112 evas_object_color_set(obj, 0, 0, 0, 0);
3113 evas_object_move(obj, 0, 0);
3114 evas_object_resize(obj, 1, 1);
3115 evas_object_layer_set(obj, 50);
3116 evas_object_pass_events_set(obj, EINA_TRUE);
3118 if (type == ELM_WIN_INLINED_IMAGE)
3119 elm_widget_parent2_set(obj, parent);
3121 /* use own version of ecore_evas_object_associate() that does TRAP() */
3122 ecore_evas_data_set(sd->ee, "elm_win", obj);
3124 evas_object_event_callback_add
3125 (obj, EVAS_CALLBACK_CHANGED_SIZE_HINTS,
3126 _elm_win_obj_callback_changed_size_hints, obj);
3128 evas_object_intercept_raise_callback_add
3129 (obj, _elm_win_obj_intercept_raise, obj);
3130 evas_object_intercept_lower_callback_add
3131 (obj, _elm_win_obj_intercept_lower, obj);
3132 evas_object_intercept_stack_above_callback_add
3133 (obj, _elm_win_obj_intercept_stack_above, obj);
3134 evas_object_intercept_stack_below_callback_add
3135 (obj, _elm_win_obj_intercept_stack_below, obj);
3136 evas_object_intercept_layer_set_callback_add
3137 (obj, _elm_win_obj_intercept_layer_set, obj);
3138 evas_object_intercept_show_callback_add
3139 (obj, _elm_win_obj_intercept_show, obj);
3141 TRAP(sd, name_class_set, name, _elm_appname);
3142 ecore_evas_callback_delete_request_set(sd->ee, _elm_win_delete_request);
3143 ecore_evas_callback_resize_set(sd->ee, _elm_win_resize);
3144 ecore_evas_callback_mouse_in_set(sd->ee, _elm_win_mouse_in);
3145 ecore_evas_callback_focus_in_set(sd->ee, _elm_win_focus_in);
3146 ecore_evas_callback_focus_out_set(sd->ee, _elm_win_focus_out);
3147 ecore_evas_callback_move_set(sd->ee, _elm_win_move);
3148 ecore_evas_callback_state_change_set(sd->ee, _elm_win_state_change);
3149 evas_object_event_callback_add(obj, EVAS_CALLBACK_HIDE, _elm_win_cb_hide, NULL);
3150 evas_object_event_callback_add(obj, EVAS_CALLBACK_SHOW, _elm_win_cb_show, NULL);
3152 evas_image_cache_set(sd->evas, (_elm_config->image_cache * 1024));
3153 evas_font_cache_set(sd->evas, (_elm_config->font_cache * 1024));
3155 EINA_LIST_FOREACH(_elm_config->font_dirs, l, fontpath)
3156 evas_font_path_append(sd->evas, fontpath);
3158 if (!_elm_config->font_hinting)
3159 evas_font_hinting_set(sd->evas, EVAS_FONT_HINTING_NONE);
3160 else if (_elm_config->font_hinting == 1)
3161 evas_font_hinting_set(sd->evas, EVAS_FONT_HINTING_AUTO);
3162 else if (_elm_config->font_hinting == 2)
3163 evas_font_hinting_set(sd->evas, EVAS_FONT_HINTING_BYTECODE);
3165 #ifdef HAVE_ELEMENTARY_X
3166 _elm_win_xwin_update(sd);
3169 _elm_win_list = eina_list_append(_elm_win_list, obj);
3172 if (((fallback) && (!strcmp(fallback, "Software FB"))) ||
3173 ((!fallback) && (ENGINE_COMPARE(ELM_SOFTWARE_FB))))
3175 TRAP(sd, fullscreen_set, 1);
3177 else if ((type != ELM_WIN_INLINED_IMAGE) &&
3178 (ENGINE_COMPARE(ELM_WAYLAND_SHM) ||
3179 ENGINE_COMPARE(ELM_WAYLAND_EGL)))
3180 _elm_win_frame_add(sd, "default");
3182 if (_elm_config->focus_highlight_enable)
3183 elm_win_focus_highlight_enabled_set(obj, EINA_TRUE);
3184 if (_elm_config->focus_highlight_animate)
3185 elm_win_focus_highlight_animate_set(obj, EINA_TRUE);
3188 Evas_Modifier_Mask mask = evas_key_modifier_mask_get(sd->evas, "Control");
3189 evas_object_event_callback_add
3190 (obj, EVAS_CALLBACK_KEY_DOWN, _debug_key_down, NULL);
3192 if (evas_object_key_grab(obj, "F12", mask, 0, EINA_TRUE))
3193 INF("Ctrl+F12 key combination exclusive for dot tree generation\n");
3195 ERR("failed to grab F12 key to elm widgets (dot) tree generation");
3198 if ((_elm_config->softcursor_mode == ELM_SOFTCURSOR_MODE_ON) ||
3199 ((_elm_config->softcursor_mode == ELM_SOFTCURSOR_MODE_AUTO) &&
3200 (((fallback) && (!strcmp(fallback, "Software FB"))) ||
3201 ((!fallback) && (ENGINE_COMPARE(ELM_SOFTWARE_FB))))))
3204 Evas_Coord mw = 1, mh = 1, hx = 0, hy = 0;
3206 sd->pointer.obj = o = edje_object_add(ecore_evas_get(tmp_sd.ee));
3207 _elm_theme_object_set(obj, o, "pointer", "base", "default");
3208 edje_object_size_min_calc(o, &mw, &mh);
3209 evas_object_resize(o, mw, mh);
3210 edje_object_part_geometry_get(o, "elm.swallow.hotspot",
3211 &hx, &hy, NULL, NULL);
3212 sd->pointer.hot_x = hx;
3213 sd->pointer.hot_y = hy;
3214 evas_object_show(o);
3215 ecore_evas_object_cursor_set(tmp_sd.ee, o, EVAS_LAYER_MAX, hx, hy);
3217 else if (_elm_config->softcursor_mode == ELM_SOFTCURSOR_MODE_OFF)
3222 sd->wm_rot.wm_supported = ecore_evas_wm_rotation_supported_get(sd->ee);
3223 sd->wm_rot.preferred_rot = -1; // it means that elm_win doesn't use preferred rotation.
3225 sd->layout = edje_object_add(sd->evas);
3226 _elm_theme_object_set(obj, sd->layout, "win", "base", "default");
3227 sd->box = evas_object_box_add(sd->evas);
3228 evas_object_box_layout_set(sd->box, _window_layout_stack, obj, NULL);
3229 edje_object_part_swallow(sd->layout, "elm.swallow.contents", sd->box);
3230 evas_object_move(sd->layout, 0, 0);
3231 evas_object_resize(sd->layout, 1, 1);
3232 edje_object_update_hints_set(sd->layout, EINA_TRUE);
3233 evas_object_event_callback_add(sd->layout, EVAS_CALLBACK_CHANGED_SIZE_HINTS,
3234 _elm_win_on_resize_obj_changed_size_hints, obj);
3235 evas_object_show(sd->layout);
3239 _constructor(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED)
3242 ERR("only custom constructor can be used with '%s' class", MY_CLASS_NAME);
3246 elm_win_type_get(const Evas_Object *obj)
3248 ELM_WIN_CHECK(obj) ELM_WIN_UNKNOWN;
3249 Elm_Win_Type ret = ELM_WIN_UNKNOWN;
3250 eo_do((Eo *) obj, elm_obj_win_type_get(&ret));
3255 _type_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3257 Elm_Win_Type *ret = va_arg(*list, Elm_Win_Type *);
3258 Elm_Win_Smart_Data *sd = _pd;
3263 elm_win_util_standard_add(const char *name,
3266 Evas_Object *win, *bg;
3268 win = elm_win_add(NULL, name, ELM_WIN_BASIC);
3269 if (!win) return NULL;
3271 elm_win_title_set(win, title);
3272 bg = elm_bg_add(win);
3275 evas_object_del(win);
3278 evas_object_size_hint_weight_set(bg, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
3279 elm_win_resize_object_add(win, bg);
3280 evas_object_show(bg);
3286 elm_win_resize_object_add(Evas_Object *obj,
3287 Evas_Object *subobj)
3290 eo_do(obj, elm_obj_win_resize_object_add(subobj));
3294 _resize_object_add(Eo *obj, void *_pd, va_list *list)
3296 Evas_Object *subobj = va_arg(*list, Evas_Object *);
3298 Elm_Win_Smart_Data *sd = _pd;
3300 elm_widget_sub_object_add(obj, subobj);
3302 if (!evas_object_box_append(sd->box, subobj))
3303 ERR("could not append %p to box", subobj);
3307 elm_win_resize_object_del(Evas_Object *obj,
3308 Evas_Object *subobj)
3311 eo_do(obj, elm_obj_win_resize_object_del(subobj));
3315 _resize_object_del(Eo *obj, void *_pd, va_list *list)
3317 Evas_Object *subobj = va_arg(*list, Evas_Object *);
3318 Elm_Win_Smart_Data *sd = _pd;
3320 if (!elm_widget_sub_object_del(obj, subobj))
3321 ERR("could not remove sub object %p from %p", subobj, obj);
3323 evas_object_box_remove(sd->box, subobj);
3327 elm_win_title_set(Evas_Object *obj,
3331 eo_do(obj, elm_obj_win_title_set(title));
3335 _title_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3337 const char *title = va_arg(*list, const char *);
3338 Elm_Win_Smart_Data *sd = _pd;
3341 eina_stringshare_replace(&(sd->title), title);
3342 TRAP(sd, title_set, sd->title);
3344 edje_object_part_text_escaped_set
3345 (sd->frame_obj, "elm.text.title", sd->title);
3349 elm_win_title_get(const Evas_Object *obj)
3351 ELM_WIN_CHECK(obj) NULL;
3352 const char *ret = NULL;
3353 eo_do((Eo *) obj, elm_obj_win_title_get(&ret));
3358 _title_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3360 const char **ret = va_arg(*list, const char **);
3361 Elm_Win_Smart_Data *sd = _pd;
3366 elm_win_icon_name_set(Evas_Object *obj,
3367 const char *icon_name)
3370 eo_do(obj, elm_obj_win_icon_name_set(icon_name));
3374 _icon_name_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3376 const char *icon_name = va_arg(*list, const char *);
3377 Elm_Win_Smart_Data *sd = _pd;
3379 if (!icon_name) return;
3380 eina_stringshare_replace(&(sd->icon_name), icon_name);
3381 #ifdef HAVE_ELEMENTARY_X
3382 _elm_win_xwin_update(sd);
3387 elm_win_icon_name_get(const Evas_Object *obj)
3389 ELM_WIN_CHECK(obj) NULL;
3390 const char *ret = NULL;
3391 eo_do((Eo *) obj, elm_obj_win_icon_name_get(&ret));
3396 _icon_name_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3398 const char **ret = va_arg(*list, const char **);
3399 Elm_Win_Smart_Data *sd = _pd;
3400 *ret = sd->icon_name;
3404 elm_win_role_set(Evas_Object *obj, const char *role)
3407 eo_do(obj, elm_obj_win_role_set(role));
3411 _role_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3413 const char *role = va_arg(*list, const char *);
3414 Elm_Win_Smart_Data *sd = _pd;
3417 eina_stringshare_replace(&(sd->role), role);
3418 #ifdef HAVE_ELEMENTARY_X
3419 _elm_win_xwin_update(sd);
3424 elm_win_role_get(const Evas_Object *obj)
3426 ELM_WIN_CHECK(obj) NULL;
3427 const char *ret = NULL;
3428 eo_do((Eo *) obj, elm_obj_win_role_get(&ret));
3433 _role_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3435 const char **ret = va_arg(*list, const char **);
3436 Elm_Win_Smart_Data *sd = _pd;
3441 elm_win_icon_object_set(Evas_Object *obj,
3445 eo_do(obj, elm_obj_win_icon_object_set(icon));
3449 _icon_object_set(Eo *obj, void *_pd, va_list *list)
3451 Evas_Object *icon = va_arg(*list, Evas_Object *);
3452 Elm_Win_Smart_Data *sd = _pd;
3455 evas_object_event_callback_del_full
3456 (sd->icon, EVAS_CALLBACK_DEL, _elm_win_on_icon_del, obj);
3459 evas_object_event_callback_add
3460 (sd->icon, EVAS_CALLBACK_DEL, _elm_win_on_icon_del, obj);
3461 #ifdef HAVE_ELEMENTARY_X
3462 _elm_win_xwin_update(sd);
3466 EAPI const Evas_Object *
3467 elm_win_icon_object_get(const Evas_Object *obj)
3469 ELM_WIN_CHECK(obj) NULL;
3470 const Evas_Object *ret = NULL;
3471 eo_do((Eo *) obj, elm_obj_win_icon_object_get(&ret));
3476 _icon_object_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3478 const Evas_Object **ret = va_arg(*list, const Evas_Object **);
3479 Elm_Win_Smart_Data *sd = _pd;
3484 elm_win_autodel_set(Evas_Object *obj,
3488 eo_do(obj, elm_obj_win_autodel_set(autodel));
3492 _autodel_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3494 Eina_Bool autodel = va_arg(*list, int);
3495 Elm_Win_Smart_Data *sd = _pd;
3496 sd->autodel = autodel;
3500 elm_win_autodel_get(const Evas_Object *obj)
3502 ELM_WIN_CHECK(obj) EINA_FALSE;
3503 Eina_Bool ret = EINA_FALSE;
3504 eo_do((Eo *) obj, elm_obj_win_autodel_get(&ret));
3509 _autodel_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3511 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3512 Elm_Win_Smart_Data *sd = _pd;
3517 elm_win_activate(Evas_Object *obj)
3520 eo_do(obj, elm_obj_win_activate());
3524 _activate(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
3526 Elm_Win_Smart_Data *sd = _pd;
3531 elm_win_lower(Evas_Object *obj)
3534 eo_do(obj, elm_obj_win_lower());
3538 _lower(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
3540 Elm_Win_Smart_Data *sd = _pd;
3545 elm_win_raise(Evas_Object *obj)
3548 eo_do(obj, elm_obj_win_raise());
3552 _raise(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
3554 Elm_Win_Smart_Data *sd = _pd;
3559 elm_win_center(Evas_Object *obj,
3564 eo_do(obj, elm_obj_win_center(h, v));
3568 _center(Eo *obj, void *_pd, va_list *list)
3570 Eina_Bool h = va_arg(*list, int);
3571 Eina_Bool v = va_arg(*list, int);
3572 int win_w, win_h, screen_w, screen_h, nx, ny;
3574 Elm_Win_Smart_Data *sd = _pd;
3576 if ((trap) && (trap->center) && (!trap->center(sd->trap_data, obj)))
3579 ecore_evas_screen_geometry_get(sd->ee, NULL, NULL, &screen_w, &screen_h);
3580 if ((!screen_w) || (!screen_h)) return;
3582 evas_object_geometry_get(obj, NULL, NULL, &win_w, &win_h);
3583 if ((!win_w) || (!win_h)) return;
3585 if (h) nx = win_w >= screen_w ? 0 : (screen_w / 2) - (win_w / 2);
3586 else nx = sd->screen.x;
3587 if (v) ny = win_h >= screen_h ? 0 : (screen_h / 2) - (win_h / 2);
3588 else ny = sd->screen.y;
3592 evas_object_move(obj, nx, ny);
3596 elm_win_borderless_set(Evas_Object *obj,
3597 Eina_Bool borderless)
3600 eo_do(obj, elm_obj_win_borderless_set(borderless));
3604 _borderless_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3606 Eina_Bool borderless = va_arg(*list, int);
3607 Elm_Win_Smart_Data *sd = _pd;
3609 Eina_Bool need_frame = EINA_FALSE;
3611 const char *engine_name = ecore_evas_engine_name_get(sd->ee);
3612 need_frame = engine_name &&
3613 ((!strcmp(engine_name, ELM_WAYLAND_SHM)) ||
3614 (!strcmp(engine_name, ELM_WAYLAND_EGL)));
3619 _elm_win_frame_del(sd);
3624 _elm_win_frame_add(sd, "default");
3627 evas_object_show(sd->frame_obj);
3630 TRAP(sd, borderless_set, borderless);
3631 #ifdef HAVE_ELEMENTARY_X
3632 _elm_win_xwin_update(sd);
3637 elm_win_borderless_get(const Evas_Object *obj)
3639 ELM_WIN_CHECK(obj) EINA_FALSE;
3640 Eina_Bool ret = EINA_FALSE;
3641 eo_do((Eo *) obj, elm_obj_win_borderless_get(&ret));
3646 _borderless_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3648 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3649 Elm_Win_Smart_Data *sd = _pd;
3650 *ret = ecore_evas_borderless_get(sd->ee);
3654 elm_win_shaped_set(Evas_Object *obj,
3658 eo_do(obj, elm_obj_win_shaped_set(shaped));
3662 _shaped_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3664 Eina_Bool shaped = va_arg(*list, int);
3665 Elm_Win_Smart_Data *sd = _pd;
3667 TRAP(sd, shaped_set, shaped);
3668 #ifdef HAVE_ELEMENTARY_X
3669 _elm_win_xwin_update(sd);
3674 elm_win_shaped_get(const Evas_Object *obj)
3676 ELM_WIN_CHECK(obj) EINA_FALSE;
3677 Eina_Bool ret = EINA_FALSE;
3678 eo_do((Eo *) obj, elm_obj_win_shaped_get(&ret));
3683 _shaped_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3685 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3686 Elm_Win_Smart_Data *sd = _pd;
3687 *ret = ecore_evas_shaped_get(sd->ee);
3691 elm_win_alpha_set(Evas_Object *obj,
3695 eo_do(obj, elm_obj_win_alpha_set(enabled));
3699 _alpha_set(Eo *obj, void *_pd, va_list *list)
3701 Eina_Bool enabled = va_arg(*list, int);
3702 Elm_Win_Smart_Data *sd = _pd;
3706 evas_object_image_alpha_set(sd->img_obj, enabled);
3707 ecore_evas_alpha_set(sd->ee, enabled);
3711 #ifdef HAVE_ELEMENTARY_X
3716 if (!ecore_x_screen_is_composited(0))
3717 elm_win_shaped_set(obj, enabled);
3719 TRAP(sd, alpha_set, enabled);
3722 TRAP(sd, alpha_set, enabled);
3723 _elm_win_xwin_update(sd);
3727 TRAP(sd, alpha_set, enabled);
3732 elm_win_alpha_get(const Evas_Object *obj)
3734 ELM_WIN_CHECK(obj) EINA_FALSE;
3735 Eina_Bool ret = EINA_FALSE;
3736 eo_do((Eo *) obj, elm_obj_win_alpha_get(&ret));
3741 _alpha_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3743 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3744 Elm_Win_Smart_Data *sd = _pd;
3748 *ret = evas_object_image_alpha_get(sd->img_obj);
3752 *ret = ecore_evas_alpha_get(sd->ee);
3757 elm_win_override_set(Evas_Object *obj,
3761 eo_do(obj, elm_obj_win_override_set(override));
3765 _override_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3767 Eina_Bool override = va_arg(*list, int);
3768 Elm_Win_Smart_Data *sd = _pd;
3770 TRAP(sd, override_set, override);
3771 #ifdef HAVE_ELEMENTARY_X
3772 _elm_win_xwin_update(sd);
3777 elm_win_override_get(const Evas_Object *obj)
3779 ELM_WIN_CHECK(obj) EINA_FALSE;
3780 Eina_Bool ret = EINA_FALSE;
3781 eo_do((Eo *) obj, elm_obj_win_override_get(&ret));
3786 _override_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3788 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3789 Elm_Win_Smart_Data *sd = _pd;
3790 *ret = ecore_evas_override_get(sd->ee);
3794 elm_win_fullscreen_set(Evas_Object *obj,
3795 Eina_Bool fullscreen)
3798 eo_do(obj, elm_obj_win_fullscreen_set(fullscreen));
3802 _fullscreen_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3804 Eina_Bool fullscreen = va_arg(*list, int);
3805 Elm_Win_Smart_Data *sd = _pd;
3806 // YYY: handle if sd->img_obj
3807 if (ENGINE_COMPARE(ELM_SOFTWARE_FB) ||
3808 ENGINE_COMPARE(ELM_SOFTWARE_16_WINCE))
3810 // these engines... can ONLY be fullscreen
3815 // sd->fullscreen = fullscreen;
3817 Eina_Bool need_frame = EINA_FALSE;
3819 const char *engine_name = ecore_evas_engine_name_get(sd->ee);
3820 need_frame = engine_name &&
3821 ((!strcmp(engine_name, ELM_WAYLAND_SHM)) ||
3822 (!strcmp(engine_name, ELM_WAYLAND_EGL)));
3824 TRAP(sd, fullscreen_set, fullscreen);
3829 _elm_win_frame_del(sd);
3834 _elm_win_frame_add(sd, "default");
3837 evas_object_show(sd->frame_obj);
3839 #ifdef HAVE_ELEMENTARY_X
3840 _elm_win_xwin_update(sd);
3846 elm_win_fullscreen_get(const Evas_Object *obj)
3848 ELM_WIN_CHECK(obj) EINA_FALSE;
3849 Eina_Bool ret = EINA_FALSE;
3850 eo_do((Eo *) obj, elm_obj_win_fullscreen_get(&ret));
3855 _fullscreen_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3857 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3858 Elm_Win_Smart_Data *sd = _pd;
3862 const char* engine_name = ecore_evas_engine_name_get(sd->ee);
3865 ((!strcmp(engine_name, ELM_SOFTWARE_FB)) ||
3866 (!strcmp(engine_name, ELM_SOFTWARE_16_WINCE))))
3868 // these engines... can ONLY be fullscreen
3873 *ret = sd->fullscreen;
3878 elm_win_main_menu_get(const Evas_Object *obj)
3880 ELM_WIN_CHECK(obj) NULL;
3882 eo_do((Eo *) obj, elm_obj_win_main_menu_get(&ret));
3887 _dbus_menu_set(Eina_Bool dbus_connect, void *data)
3889 ELM_WIN_DATA_GET_OR_RETURN(data, sd);
3893 DBG("Setting menu to D-Bus");
3894 edje_object_part_unswallow(sd->layout, sd->main_menu);
3895 edje_object_signal_emit(sd->layout, "elm,action,hide_menu", "elm");
3896 _elm_menu_menu_bar_hide(sd->main_menu);
3900 DBG("Setting menu to local mode");
3901 edje_object_part_swallow(sd->layout, "elm.swallow.menu", sd->main_menu);
3902 edje_object_signal_emit(sd->layout, "elm,action,show_menu", "elm");
3903 evas_object_show(sd->main_menu);
3908 _main_menu_get(Eo *obj, void *_pd, va_list *list)
3910 Eo **ret = va_arg(*list, Eo **);
3911 Elm_Win_Smart_Data *sd = _pd;
3912 Eina_Bool use_dbus = EINA_FALSE;
3914 if (sd->main_menu) goto end;
3916 sd->main_menu = elm_menu_add(obj);
3917 _elm_menu_menu_bar_set(sd->main_menu, EINA_TRUE);
3919 #ifdef HAVE_ELEMENTARY_X
3920 if (!_elm_config->disable_external_menu && sd->x.xwin) use_dbus = EINA_TRUE;
3923 #ifdef HAVE_ELEMENTARY_X
3924 if (use_dbus && _elm_dbus_menu_register(sd->main_menu))
3926 _elm_dbus_menu_app_menu_register(sd->x.xwin, sd->main_menu,
3927 _dbus_menu_set, obj);
3931 _dbus_menu_set(EINA_FALSE, obj);
3934 *ret = sd->main_menu;
3938 elm_win_maximized_set(Evas_Object *obj,
3939 Eina_Bool maximized)
3942 eo_do(obj, elm_obj_win_maximized_set(maximized));
3946 _maximized_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3948 Eina_Bool maximized = va_arg(*list, int);
3949 Elm_Win_Smart_Data *sd = _pd;
3951 _elm_win_frame_maximized_state_update(sd, maximized);
3952 // YYY: handle if sd->img_obj
3953 TRAP(sd, maximized_set, maximized);
3954 #ifdef HAVE_ELEMENTARY_X
3955 _elm_win_xwin_update(sd);
3960 elm_win_maximized_get(const Evas_Object *obj)
3962 ELM_WIN_CHECK(obj) EINA_FALSE;
3963 Eina_Bool ret = EINA_FALSE;
3964 eo_do((Eo *) obj, elm_obj_win_maximized_get(&ret));
3969 _maximized_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3971 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3972 Elm_Win_Smart_Data *sd = _pd;
3973 *ret = sd->maximized;
3977 elm_win_iconified_set(Evas_Object *obj,
3978 Eina_Bool iconified)
3981 eo_do(obj, elm_obj_win_iconified_set(iconified));
3985 _iconified_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3987 Eina_Bool iconified = va_arg(*list, int);
3988 Elm_Win_Smart_Data *sd = _pd;
3990 // sd->iconified = iconified;
3991 TRAP(sd, iconified_set, iconified);
3992 #ifdef HAVE_ELEMENTARY_X
3993 _elm_win_xwin_update(sd);
3998 elm_win_iconified_get(const Evas_Object *obj)
4000 ELM_WIN_CHECK(obj) EINA_FALSE;
4001 Eina_Bool ret = EINA_FALSE;
4002 eo_do((Eo *) obj, elm_obj_win_iconified_get(&ret));
4007 _iconified_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4009 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4010 Elm_Win_Smart_Data *sd = _pd;
4011 *ret = sd->iconified;
4015 elm_win_withdrawn_set(Evas_Object *obj,
4016 Eina_Bool withdrawn)
4019 eo_do(obj, elm_obj_win_withdrawn_set(withdrawn));
4023 _withdrawn_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4025 Eina_Bool withdrawn = va_arg(*list, int);
4026 Elm_Win_Smart_Data *sd = _pd;
4028 // sd->withdrawn = withdrawn;
4029 TRAP(sd, withdrawn_set, withdrawn);
4030 #ifdef HAVE_ELEMENTARY_X
4031 _elm_win_xwin_update(sd);
4036 elm_win_withdrawn_get(const Evas_Object *obj)
4038 ELM_WIN_CHECK(obj) EINA_FALSE;
4039 Eina_Bool ret = EINA_FALSE;
4040 eo_do((Eo *) obj, elm_obj_win_withdrawn_get(&ret));
4045 _withdrawn_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4047 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4048 Elm_Win_Smart_Data *sd = _pd;
4049 *ret = sd->withdrawn;
4053 elm_win_available_profiles_set(Evas_Object *obj,
4054 const char **profiles,
4058 eo_do((Eo *) obj, elm_obj_win_available_profiles_set(profiles, count));
4062 _available_profiles_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4064 const char **profiles = va_arg(*list, const char **);
4065 unsigned int count = va_arg(*list, unsigned int);
4066 Elm_Win_Smart_Data *sd = _pd;
4067 Eina_Bool found = EINA_FALSE;
4069 _elm_win_available_profiles_del(sd);
4070 if ((profiles) && (count >= 1))
4072 sd->profile.available_list = calloc(count, sizeof(char *));
4073 if (sd->profile.available_list)
4075 if (!sd->profile.name) found = EINA_TRUE;
4078 for (i = 0; i < count; i++)
4080 sd->profile.available_list[i] = eina_stringshare_add(profiles[i]);
4082 /* check to see if a given array has a current profile of elm_win */
4083 if ((sd->profile.name) &&
4084 (!strcmp(sd->profile.name, profiles[i])))
4089 sd->profile.count = count;
4093 if (ecore_evas_window_profile_supported_get(sd->ee))
4095 ecore_evas_window_available_profiles_set(sd->ee,
4096 sd->profile.available_list,
4099 /* current profile of elm_win is wrong, change profile */
4100 if ((sd->profile.available_list) && (!found))
4102 eina_stringshare_replace(&(sd->profile.name),
4103 sd->profile.available_list[0]);
4104 ecore_evas_window_profile_set(sd->ee, sd->profile.name);
4110 if (sd->profile.available_list)
4111 _elm_win_profile_update(sd);
4116 elm_win_available_profiles_get(Evas_Object *obj,
4118 unsigned int *count)
4120 ELM_WIN_CHECK(obj) EINA_FALSE;
4121 Eina_Bool ret = EINA_FALSE;
4122 eo_do((Eo *) obj, elm_obj_win_available_profiles_get(profiles, count, &ret));
4127 _available_profiles_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4129 char ***profiles = va_arg(*list, char ***);
4130 unsigned int *count = va_arg(*list, unsigned int *);
4131 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4132 Elm_Win_Smart_Data *sd = _pd;
4135 if (ecore_evas_window_profile_supported_get(sd->ee))
4137 res = ecore_evas_window_available_profiles_get(sd->ee,
4143 if (profiles) *profiles = (char **)sd->profile.available_list;
4144 if (count) *count = sd->profile.count;
4147 if (ret) *ret = res;
4151 elm_win_profile_set(Evas_Object *obj,
4152 const char *profile)
4155 eo_do((Eo *) obj, elm_obj_win_profile_set(profile));
4159 _profile_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4161 const char *profile = va_arg(*list, const char *);
4162 Elm_Win_Smart_Data *sd = _pd;
4164 /* check to see if a given profile is present in an available profiles */
4165 if ((profile) && (sd->profile.available_list))
4167 Eina_Bool found = EINA_FALSE;
4169 for (i = 0; i < sd->profile.count; i++)
4171 if (!strcmp(profile,
4172 sd->profile.available_list[i]))
4181 if (ecore_evas_window_profile_supported_get(sd->ee))
4183 if (!profile) _elm_win_profile_del(sd);
4184 ecore_evas_window_profile_set(sd->ee, profile);
4188 if (_elm_win_profile_set(sd, profile))
4189 _elm_win_profile_update(sd);
4194 elm_win_profile_get(const Evas_Object *obj)
4196 ELM_WIN_CHECK(obj) NULL;
4197 const char *ret = NULL;
4198 eo_do((Eo *) obj, elm_obj_win_profile_get(&ret));
4203 _profile_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4205 const char **ret = va_arg(*list, const char **);
4206 Elm_Win_Smart_Data *sd = _pd;
4207 *ret = sd->profile.name;
4211 elm_win_urgent_set(Evas_Object *obj,
4215 eo_do(obj, elm_obj_win_urgent_set(urgent));
4219 _urgent_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4221 Eina_Bool urgent = va_arg(*list, int);
4222 Elm_Win_Smart_Data *sd = _pd;
4224 sd->urgent = urgent;
4225 TRAP(sd, urgent_set, urgent);
4226 #ifdef HAVE_ELEMENTARY_X
4227 _elm_win_xwin_update(sd);
4232 elm_win_urgent_get(const Evas_Object *obj)
4234 ELM_WIN_CHECK(obj) EINA_FALSE;
4235 Eina_Bool ret = EINA_FALSE;
4236 eo_do((Eo *) obj, elm_obj_win_urgent_get(&ret));
4241 _urgent_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4243 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4244 Elm_Win_Smart_Data *sd = _pd;
4249 elm_win_demand_attention_set(Evas_Object *obj,
4250 Eina_Bool demand_attention)
4253 eo_do(obj, elm_obj_win_demand_attention_set(demand_attention));
4257 _demand_attention_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4259 Eina_Bool demand_attention = va_arg(*list, int);
4260 Elm_Win_Smart_Data *sd = _pd;
4262 sd->demand_attention = demand_attention;
4263 TRAP(sd, demand_attention_set, demand_attention);
4264 #ifdef HAVE_ELEMENTARY_X
4265 _elm_win_xwin_update(sd);
4270 elm_win_demand_attention_get(const Evas_Object *obj)
4272 ELM_WIN_CHECK(obj) EINA_FALSE;
4273 Eina_Bool ret = EINA_FALSE;
4274 eo_do((Eo *) obj, elm_obj_win_demand_attention_get(&ret));
4279 _demand_attention_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4281 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4282 Elm_Win_Smart_Data *sd = _pd;
4283 *ret = sd->demand_attention;
4287 elm_win_modal_set(Evas_Object *obj,
4291 eo_do(obj, elm_obj_win_modal_set(modal));
4295 _modal_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4297 Eina_Bool modal = va_arg(*list, int);
4298 Elm_Win_Smart_Data *sd = _pd;
4301 TRAP(sd, modal_set, modal);
4302 #ifdef HAVE_ELEMENTARY_X
4303 _elm_win_xwin_update(sd);
4308 elm_win_modal_get(const Evas_Object *obj)
4310 ELM_WIN_CHECK(obj) EINA_FALSE;
4311 Eina_Bool ret = EINA_FALSE;
4312 eo_do((Eo *) obj, elm_obj_win_modal_get(&ret));
4317 _modal_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4319 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4320 Elm_Win_Smart_Data *sd = _pd;
4325 elm_win_aspect_set(Evas_Object *obj,
4329 eo_do(obj, elm_obj_win_aspect_set(aspect));
4333 _aspect_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4335 double aspect = va_arg(*list, double);
4336 Elm_Win_Smart_Data *sd = _pd;
4338 sd->aspect = aspect;
4339 TRAP(sd, aspect_set, aspect);
4340 #ifdef HAVE_ELEMENTARY_X
4341 _elm_win_xwin_update(sd);
4346 elm_win_aspect_get(const Evas_Object *obj)
4348 ELM_WIN_CHECK(obj) 0.0;
4350 eo_do((Eo *) obj, elm_obj_win_aspect_get(&ret));
4355 _aspect_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4357 double *ret = va_arg(*list, double *);
4358 Elm_Win_Smart_Data *sd = _pd;
4363 elm_win_size_base_set(Evas_Object *obj, int w, int h)
4366 eo_do(obj, elm_obj_win_size_base_set(w, h));
4370 _size_base_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4372 int w = va_arg(*list, int);
4373 int h = va_arg(*list, int);
4374 Elm_Win_Smart_Data *sd = _pd;
4375 sd->size_base_w = w;
4376 sd->size_base_h = h;
4377 TRAP(sd, size_base_set, w, h);
4378 #ifdef HAVE_ELEMENTARY_X
4379 _elm_win_xwin_update(sd);
4384 elm_win_size_base_get(Evas_Object *obj, int *w, int *h)
4387 eo_do(obj, elm_obj_win_size_base_get(w, h));
4391 _size_base_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4393 int *w = va_arg(*list, int *);
4394 int *h = va_arg(*list, int *);
4396 Elm_Win_Smart_Data *sd = _pd;
4397 if (w) *w = sd->size_base_w;
4398 if (w) *h = sd->size_base_h;
4402 elm_win_size_step_set(Evas_Object *obj, int w, int h)
4405 eo_do(obj, elm_obj_win_size_step_set(w, h));
4409 _size_step_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4411 int w = va_arg(*list, int);
4412 int h = va_arg(*list, int);
4413 Elm_Win_Smart_Data *sd = _pd;
4414 sd->size_step_w = w;
4415 sd->size_step_h = h;
4416 TRAP(sd, size_step_set, w, h);
4417 #ifdef HAVE_ELEMENTARY_X
4418 _elm_win_xwin_update(sd);
4423 elm_win_size_step_get(Evas_Object *obj, int *w, int *h)
4426 eo_do(obj, elm_obj_win_size_step_get(w, h));
4430 _size_step_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4432 int *w = va_arg(*list, int *);
4433 int *h = va_arg(*list, int *);
4434 Elm_Win_Smart_Data *sd = _pd;
4435 if (w) *w = sd->size_step_w;
4436 if (w) *h = sd->size_step_h;
4440 elm_win_layer_set(Evas_Object *obj,
4444 eo_do(obj, elm_obj_win_layer_set(layer));
4448 _layer_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4450 int layer = va_arg(*list, int);
4451 Elm_Win_Smart_Data *sd = _pd;
4453 TRAP(sd, layer_set, layer);
4454 #ifdef HAVE_ELEMENTARY_X
4455 _elm_win_xwin_update(sd);
4460 elm_win_layer_get(const Evas_Object *obj)
4462 ELM_WIN_CHECK(obj) - 1;
4464 eo_do((Eo *) obj, elm_obj_win_layer_get(&ret));
4469 _layer_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4471 int *ret = va_arg(*list, int *);
4472 Elm_Win_Smart_Data *sd = _pd;
4473 *ret = ecore_evas_layer_get(sd->ee);
4477 elm_win_norender_push(Evas_Object *obj)
4480 ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
4483 if (sd->norender == 1) ecore_evas_manual_render_set(sd->ee, EINA_TRUE);
4487 elm_win_norender_pop(Evas_Object *obj)
4490 ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
4492 if (sd->norender <= 0) return;
4494 if (sd->norender == 0) ecore_evas_manual_render_set(sd->ee, EINA_FALSE);
4498 elm_win_norender_get(Evas_Object *obj)
4500 ELM_WIN_CHECK(obj) - 1;
4501 ELM_WIN_DATA_GET_OR_RETURN_VAL(obj, sd, -1);
4502 return sd->norender;
4506 elm_win_render(Evas_Object *obj)
4509 ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
4510 ecore_evas_manual_render(sd->ee);
4514 _win_rotation_degree_check(int rotation)
4516 if ((rotation > 360) || (rotation < 0))
4518 WRN("Rotation degree should be 0 ~ 360 (passed degree: %d)", rotation);
4520 if (rotation < 0) rotation += 360;
4526 * This API resizes the internal window(ex: X window) and evas_output.
4527 * But this does not resize the elm window object and its contents.
4530 elm_win_rotation_set(Evas_Object *obj,
4534 eo_do(obj, elm_obj_win_rotation_set(rotation));
4538 _win_rotate(Evas_Object *obj, Elm_Win_Smart_Data *sd, int rotation, Eina_Bool resize)
4540 rotation = _win_rotation_degree_check(rotation);
4541 if (sd->rot == rotation) return;
4543 if (resize) TRAP(sd, rotation_with_resize_set, rotation);
4544 else TRAP(sd, rotation_set, rotation);
4545 evas_object_size_hint_min_set(obj, -1, -1);
4546 evas_object_size_hint_max_set(obj, -1, -1);
4547 _elm_win_resize_objects_eval(obj);
4548 #ifdef HAVE_ELEMENTARY_X
4549 _elm_win_xwin_update(sd);
4551 _elm_win_frame_obj_update(sd);
4552 elm_widget_orientation_set(obj, rotation);
4553 evas_object_smart_callback_call(obj, SIG_ROTATION_CHANGED, NULL);
4557 _rotation_set(Eo *obj, void *_pd, va_list *list)
4559 int rotation = va_arg(*list, int);
4560 Elm_Win_Smart_Data *sd = _pd;
4561 _win_rotate(obj, sd, rotation, EINA_FALSE);
4565 * This API does not resize the internal window (ex: X window).
4566 * But this resizes evas_output, elm window, and its contents.
4569 elm_win_rotation_with_resize_set(Evas_Object *obj,
4573 eo_do(obj, elm_obj_win_rotation_with_resize_set(rotation));
4577 _rotation_with_resize_set(Eo *obj, void *_pd, va_list *list)
4579 int rotation = va_arg(*list, int);
4580 Elm_Win_Smart_Data *sd = _pd;
4581 _win_rotate(obj, sd, rotation, EINA_TRUE);
4585 elm_win_rotation_get(const Evas_Object *obj)
4587 ELM_WIN_CHECK(obj) - 1;
4589 eo_do((Eo *) obj, elm_obj_win_rotation_get(&ret));
4594 _rotation_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4596 int *ret = va_arg(*list, int *);
4597 Elm_Win_Smart_Data *sd = _pd;
4602 elm_win_wm_rotation_supported_get(const Evas_Object *obj)
4604 ELM_WIN_CHECK(obj) EINA_FALSE;
4605 Eina_Bool ret = EINA_FALSE;
4606 eo_do((Eo *) obj, elm_obj_win_wm_rotation_supported_get(&ret));
4611 _wm_rotation_supported_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4613 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4614 Elm_Win_Smart_Data *sd = _pd;
4615 *ret = sd->wm_rot.wm_supported;
4618 /* This will unset a preferred rotation, if given preferred rotation is '-1'.
4621 elm_win_wm_rotation_preferred_rotation_set(const Evas_Object *obj,
4625 eo_do((Eo *) obj, elm_obj_win_wm_preferred_rotation_set(rotation));
4629 _wm_preferred_rotation_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4631 int rotation = va_arg(*list, int);
4633 Elm_Win_Smart_Data *sd = _pd;
4635 if (!sd->wm_rot.use)
4636 sd->wm_rot.use = EINA_TRUE;
4638 // '-1' means that elm_win doesn't use preferred rotation.
4642 rot = _win_rotation_degree_check(rotation);
4644 if (sd->wm_rot.preferred_rot == rot) return;
4645 sd->wm_rot.preferred_rot = rot;
4647 ecore_evas_wm_rotation_preferred_rotation_set(sd->ee, rot);
4651 elm_win_wm_rotation_preferred_rotation_get(const Evas_Object *obj)
4653 ELM_WIN_CHECK(obj) -1;
4655 eo_do((Eo *) obj, elm_obj_win_wm_preferred_rotation_get(&ret));
4660 _wm_preferred_rotation_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4662 int *ret = va_arg(*list, int *);
4663 Elm_Win_Smart_Data *sd = _pd;
4664 *ret = sd->wm_rot.preferred_rot;
4668 elm_win_wm_rotation_available_rotations_set(Evas_Object *obj,
4669 const int *rotations,
4673 eo_do((Eo *) obj, elm_obj_win_wm_available_rotations_set(rotations, count));
4677 _wm_available_rotations_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4679 const int *rotations = va_arg(*list, const int *);
4680 unsigned int count = va_arg(*list, unsigned int);
4681 Elm_Win_Smart_Data *sd = _pd;
4685 if (!sd->wm_rot.use)
4686 sd->wm_rot.use = EINA_TRUE;
4688 ELM_SAFE_FREE(sd->wm_rot.rots, free);
4689 sd->wm_rot.count = 0;
4693 sd->wm_rot.rots = calloc(count, sizeof(int));
4694 if (!sd->wm_rot.rots) return;
4695 for (i = 0; i < count; i++)
4697 r = _win_rotation_degree_check(rotations[i]);
4698 sd->wm_rot.rots[i] = r;
4702 sd->wm_rot.count = count;
4704 ecore_evas_wm_rotation_available_rotations_set(sd->ee,
4710 elm_win_wm_rotation_available_rotations_get(const Evas_Object *obj,
4712 unsigned int *count)
4714 ELM_WIN_CHECK(obj) EINA_FALSE;
4715 Eina_Bool ret = EINA_FALSE;
4716 eo_do((Eo *) obj, elm_obj_win_wm_available_rotations_get(rotations, count, &ret));
4721 _wm_available_rotations_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4723 int **rotations = va_arg(*list, int **);
4724 unsigned int *count = va_arg(*list, unsigned int *);
4725 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4726 Elm_Win_Smart_Data *sd = _pd;
4728 if (!sd->wm_rot.use) return;
4730 if (sd->wm_rot.count > 0)
4734 *rotations = calloc(sd->wm_rot.count, sizeof(int));
4739 sizeof(int) * sd->wm_rot.count);
4744 if (count) *count = sd->wm_rot.count;
4749 elm_win_wm_rotation_manual_rotation_done_set(Evas_Object *obj,
4753 eo_do((Eo *) obj, elm_obj_win_wm_manual_rotation_done_set(set));
4757 _wm_manual_rotation_done_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4759 int set = va_arg(*list, int);
4760 Elm_Win_Smart_Data *sd = _pd;
4761 if (!sd->wm_rot.use) return;
4762 ecore_evas_wm_rotation_manual_rotation_done_set(sd->ee, set);
4766 elm_win_wm_rotation_manual_rotation_done_get(const Evas_Object *obj)
4768 ELM_WIN_CHECK(obj) EINA_FALSE;
4769 Eina_Bool ret = EINA_FALSE;
4770 eo_do((Eo *) obj, elm_obj_win_wm_manual_rotation_done_get(&ret));
4775 _wm_manual_rotation_done_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4777 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4778 Elm_Win_Smart_Data *sd = _pd;
4779 if (!sd->wm_rot.use) return;
4780 *ret = ecore_evas_wm_rotation_manual_rotation_done_get(sd->ee);
4784 elm_win_wm_rotation_manual_rotation_done(Evas_Object *obj)
4787 eo_do((Eo *) obj, elm_obj_win_wm_manual_rotation_done());
4791 _wm_manual_rotation_done(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
4793 Elm_Win_Smart_Data *sd = _pd;
4794 if (!sd->wm_rot.use) return;
4795 ecore_evas_wm_rotation_manual_rotation_done(sd->ee);
4799 elm_win_sticky_set(Evas_Object *obj,
4803 eo_do(obj, elm_obj_win_sticky_set(sticky));
4807 _sticky_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4809 Eina_Bool sticky = va_arg(*list, int);
4810 Elm_Win_Smart_Data *sd = _pd;
4812 // sd->sticky = sticky;
4813 TRAP(sd, sticky_set, sticky);
4814 #ifdef HAVE_ELEMENTARY_X
4815 _elm_win_xwin_update(sd);
4820 elm_win_sticky_get(const Evas_Object *obj)
4822 ELM_WIN_CHECK(obj) EINA_FALSE;
4823 Eina_Bool ret = EINA_FALSE;
4824 eo_do((Eo *) obj, elm_obj_win_sticky_get(&ret));
4829 _sticky_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4831 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4832 Elm_Win_Smart_Data *sd = _pd;
4837 elm_win_keyboard_mode_set(Evas_Object *obj,
4838 Elm_Win_Keyboard_Mode mode)
4841 eo_do(obj, elm_obj_win_keyboard_mode_set(mode));
4845 _keyboard_mode_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4847 Elm_Win_Keyboard_Mode mode = va_arg(*list, Elm_Win_Keyboard_Mode);
4848 Elm_Win_Smart_Data *sd = _pd;
4850 if (mode == sd->kbdmode) return;
4851 #ifdef HAVE_ELEMENTARY_X
4852 _elm_win_xwindow_get(sd);
4855 #ifdef HAVE_ELEMENTARY_X
4857 ecore_x_e_virtual_keyboard_state_set
4858 (sd->x.xwin, (Ecore_X_Virtual_Keyboard_State)sd->kbdmode);
4862 EAPI Elm_Win_Keyboard_Mode
4863 elm_win_keyboard_mode_get(const Evas_Object *obj)
4865 ELM_WIN_CHECK(obj) ELM_WIN_KEYBOARD_UNKNOWN;
4866 Elm_Win_Keyboard_Mode ret = ELM_WIN_KEYBOARD_UNKNOWN;
4867 eo_do((Eo *) obj, elm_obj_win_keyboard_mode_get(&ret));
4872 _keyboard_mode_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4874 Elm_Win_Keyboard_Mode *ret = va_arg(*list, Elm_Win_Keyboard_Mode *);
4875 Elm_Win_Smart_Data *sd = _pd;
4880 elm_win_keyboard_win_set(Evas_Object *obj,
4881 Eina_Bool is_keyboard)
4884 eo_do(obj, elm_obj_win_keyboard_win_set(is_keyboard));
4888 _keyboard_win_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4890 Eina_Bool is_keyboard = va_arg(*list, int);
4891 Elm_Win_Smart_Data *sd = _pd;
4893 #ifdef HAVE_ELEMENTARY_X
4894 _elm_win_xwindow_get(sd);
4896 ecore_x_e_virtual_keyboard_set(sd->x.xwin, is_keyboard);
4903 elm_win_keyboard_win_get(const Evas_Object *obj)
4905 ELM_WIN_CHECK(obj) EINA_FALSE;
4906 Eina_Bool ret = EINA_FALSE;
4907 eo_do((Eo *) obj, elm_obj_win_keyboard_win_get(&ret));
4912 _keyboard_win_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4914 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4915 Elm_Win_Smart_Data *sd = _pd;
4917 #ifdef HAVE_ELEMENTARY_X
4918 _elm_win_xwindow_get(sd);
4921 *ret = ecore_x_e_virtual_keyboard_get(sd->x.xwin);
4929 elm_win_indicator_mode_set(Evas_Object *obj,
4930 Elm_Win_Indicator_Mode mode)
4933 eo_do(obj, elm_obj_win_indicator_mode_set(mode));
4937 _indicator_mode_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4939 Elm_Win_Indicator_Mode mode = va_arg(*list, Elm_Win_Indicator_Mode);
4940 Elm_Win_Smart_Data *sd = _pd;
4942 if (mode == sd->indmode) return;
4943 #ifdef HAVE_ELEMENTARY_X
4944 _elm_win_xwindow_get(sd);
4947 #ifdef HAVE_ELEMENTARY_X
4950 if (sd->indmode == ELM_WIN_INDICATOR_SHOW)
4951 ecore_x_e_illume_indicator_state_set
4952 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_STATE_ON);
4953 else if (sd->indmode == ELM_WIN_INDICATOR_HIDE)
4954 ecore_x_e_illume_indicator_state_set
4955 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_STATE_OFF);
4958 evas_object_smart_callback_call(obj, SIG_INDICATOR_PROP_CHANGED, NULL);
4961 EAPI Elm_Win_Indicator_Mode
4962 elm_win_indicator_mode_get(const Evas_Object *obj)
4964 ELM_WIN_CHECK(obj) ELM_WIN_INDICATOR_UNKNOWN;
4965 Elm_Win_Indicator_Mode ret = ELM_WIN_INDICATOR_UNKNOWN;
4966 eo_do((Eo *) obj, elm_obj_win_indicator_mode_get(&ret));
4971 _indicator_mode_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4973 Elm_Win_Indicator_Mode *ret = va_arg(*list, Elm_Win_Indicator_Mode *);
4974 Elm_Win_Smart_Data *sd = _pd;
4979 elm_win_indicator_opacity_set(Evas_Object *obj,
4980 Elm_Win_Indicator_Opacity_Mode mode)
4983 eo_do(obj, elm_obj_win_indicator_opacity_set(mode));
4987 _indicator_opacity_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4989 Elm_Win_Indicator_Opacity_Mode mode = va_arg(*list, Elm_Win_Indicator_Opacity_Mode);
4990 Elm_Win_Smart_Data *sd = _pd;
4992 if (mode == sd->ind_o_mode) return;
4993 sd->ind_o_mode = mode;
4994 #ifdef HAVE_ELEMENTARY_X
4995 _elm_win_xwindow_get(sd);
4998 if (sd->ind_o_mode == ELM_WIN_INDICATOR_OPAQUE)
4999 ecore_x_e_illume_indicator_opacity_set
5000 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_OPAQUE);
5001 else if (sd->ind_o_mode == ELM_WIN_INDICATOR_TRANSLUCENT)
5002 ecore_x_e_illume_indicator_opacity_set
5003 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_TRANSLUCENT);
5004 else if (sd->ind_o_mode == ELM_WIN_INDICATOR_TRANSPARENT)
5005 ecore_x_e_illume_indicator_opacity_set
5006 (sd->x.xwin, ECORE_X_ILLUME_INDICATOR_TRANSPARENT);
5009 evas_object_smart_callback_call(obj, SIG_INDICATOR_PROP_CHANGED, NULL);
5012 EAPI Elm_Win_Indicator_Opacity_Mode
5013 elm_win_indicator_opacity_get(const Evas_Object *obj)
5015 ELM_WIN_CHECK(obj) ELM_WIN_INDICATOR_OPACITY_UNKNOWN;
5016 Elm_Win_Indicator_Opacity_Mode ret = ELM_WIN_INDICATOR_OPACITY_UNKNOWN;
5017 eo_do((Eo *) obj, elm_obj_win_indicator_opacity_get(&ret));
5022 _indicator_opacity_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5024 Elm_Win_Indicator_Opacity_Mode *ret = va_arg(*list, Elm_Win_Indicator_Opacity_Mode *);
5025 Elm_Win_Smart_Data *sd = _pd;
5026 *ret = sd->ind_o_mode;
5030 elm_win_screen_position_get(const Evas_Object *obj,
5035 eo_do((Eo *) obj, elm_obj_win_screen_position_get(x, y));
5039 _screen_position_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5041 int *x = va_arg(*list, int *);
5042 int *y = va_arg(*list, int *);
5043 Elm_Win_Smart_Data *sd = _pd;
5045 if (x) *x = sd->screen.x;
5046 if (y) *y = sd->screen.y;
5050 elm_win_focus_get(const Evas_Object *obj)
5052 ELM_WIN_CHECK(obj) EINA_FALSE;
5053 Eina_Bool ret = EINA_FALSE;
5054 eo_do((Eo *) obj, elm_obj_win_focus_get(&ret));
5059 _focus_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5061 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5062 Elm_Win_Smart_Data *sd = _pd;
5063 *ret = ecore_evas_focus_get(sd->ee);
5067 elm_win_screen_constrain_set(Evas_Object *obj,
5068 Eina_Bool constrain)
5071 eo_do(obj, elm_obj_win_screen_constrain_set(constrain));
5075 _screen_constrain_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5077 Eina_Bool constrain = va_arg(*list, int);
5078 Elm_Win_Smart_Data *sd = _pd;
5079 sd->constrain = !!constrain;
5083 elm_win_screen_constrain_get(Evas_Object *obj)
5085 ELM_WIN_CHECK(obj) EINA_FALSE;
5086 Eina_Bool ret = EINA_FALSE;
5087 eo_do(obj, elm_obj_win_screen_constrain_get(&ret));
5092 _screen_constrain_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5094 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5095 Elm_Win_Smart_Data *sd = _pd;
5096 *ret = sd->constrain;
5100 elm_win_screen_size_get(const Evas_Object *obj,
5107 eo_do((Eo *) obj, elm_obj_win_screen_size_get(x, y, w, h));
5111 _screen_size_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5113 int *x = va_arg(*list, int *);
5114 int *y = va_arg(*list, int *);
5115 int *w = va_arg(*list, int *);
5116 int *h = va_arg(*list, int *);
5117 Elm_Win_Smart_Data *sd = _pd;
5119 ecore_evas_screen_geometry_get(sd->ee, x, y, w, h);
5123 elm_win_screen_dpi_get(const Evas_Object *obj,
5128 eo_do((Eo *) obj, elm_obj_win_screen_dpi_get(xdpi, ydpi));
5132 _screen_dpi_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5134 int *xdpi = va_arg(*list, int *);
5135 int *ydpi = va_arg(*list, int *);
5136 Elm_Win_Smart_Data *sd = _pd;
5138 ecore_evas_screen_dpi_get(sd->ee, xdpi, ydpi);
5142 elm_win_conformant_set(Evas_Object *obj,
5143 Eina_Bool conformant)
5146 eo_do(obj, elm_obj_win_conformant_set(conformant));
5150 _conformant_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5152 Eina_Bool conformant = va_arg(*list, int);
5153 Elm_Win_Smart_Data *sd = _pd;
5155 #ifdef HAVE_ELEMENTARY_X
5156 _elm_win_xwindow_get(sd);
5158 ecore_x_e_illume_conformant_set(sd->x.xwin, conformant);
5165 elm_win_conformant_get(const Evas_Object *obj)
5167 ELM_WIN_CHECK(obj) EINA_FALSE;
5168 Eina_Bool ret = EINA_FALSE;
5169 eo_do((Eo *) obj, elm_obj_win_conformant_get(&ret));
5174 _conformant_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5176 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5177 Elm_Win_Smart_Data *sd = _pd;
5180 #ifdef HAVE_ELEMENTARY_X
5181 _elm_win_xwindow_get(sd);
5183 *ret = ecore_x_e_illume_conformant_get(sd->x.xwin);
5188 elm_win_quickpanel_set(Evas_Object *obj,
5189 Eina_Bool quickpanel)
5192 eo_do(obj, elm_obj_win_quickpanel_set(quickpanel));
5196 _quickpanel_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5198 Eina_Bool quickpanel = va_arg(*list, int);
5199 Elm_Win_Smart_Data *sd = _pd;
5200 #ifdef HAVE_ELEMENTARY_X
5201 _elm_win_xwindow_get(sd);
5204 ecore_x_e_illume_quickpanel_set(sd->x.xwin, quickpanel);
5207 Ecore_X_Window_State states[2];
5209 states[0] = ECORE_X_WINDOW_STATE_SKIP_TASKBAR;
5210 states[1] = ECORE_X_WINDOW_STATE_SKIP_PAGER;
5211 ecore_x_netwm_window_state_set(sd->x.xwin, states, 2);
5212 ecore_x_icccm_hints_set(sd->x.xwin, 0, 0, 0, 0, 0, 0, 0);
5221 elm_win_quickpanel_get(const Evas_Object *obj)
5223 ELM_WIN_CHECK(obj) EINA_FALSE;
5224 Eina_Bool ret = EINA_FALSE;
5225 eo_do((Eo *) obj, elm_obj_win_quickpanel_get(&ret));
5230 _quickpanel_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5232 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5233 Elm_Win_Smart_Data *sd = _pd;
5236 #ifdef HAVE_ELEMENTARY_X
5237 _elm_win_xwindow_get(sd);
5239 *ret = ecore_x_e_illume_quickpanel_get(sd->x.xwin);
5244 elm_win_quickpanel_priority_major_set(Evas_Object *obj,
5248 eo_do(obj, elm_obj_win_quickpanel_priority_major_set(priority));
5252 _quickpanel_priority_major_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5254 int priority = va_arg(*list, int);
5255 Elm_Win_Smart_Data *sd = _pd;
5257 #ifdef HAVE_ELEMENTARY_X
5258 _elm_win_xwindow_get(sd);
5260 ecore_x_e_illume_quickpanel_priority_major_set(sd->x.xwin, priority);
5267 elm_win_quickpanel_priority_major_get(const Evas_Object *obj)
5269 ELM_WIN_CHECK(obj) - 1;
5271 eo_do((Eo *) obj, elm_obj_win_quickpanel_priority_major_get(&ret));
5276 _quickpanel_priority_major_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5278 int *ret = va_arg(*list, int *);
5279 Elm_Win_Smart_Data *sd = _pd;
5282 #ifdef HAVE_ELEMENTARY_X
5283 _elm_win_xwindow_get(sd);
5285 *ret = ecore_x_e_illume_quickpanel_priority_major_get(sd->x.xwin);
5290 elm_win_quickpanel_priority_minor_set(Evas_Object *obj,
5294 eo_do(obj, elm_obj_win_quickpanel_priority_minor_set(priority));
5298 _quickpanel_priority_minor_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5300 int priority = va_arg(*list, int);
5301 Elm_Win_Smart_Data *sd = _pd;
5303 #ifdef HAVE_ELEMENTARY_X
5304 _elm_win_xwindow_get(sd);
5306 ecore_x_e_illume_quickpanel_priority_minor_set(sd->x.xwin, priority);
5313 elm_win_quickpanel_priority_minor_get(const Evas_Object *obj)
5315 ELM_WIN_CHECK(obj) - 1;
5317 eo_do((Eo *) obj, elm_obj_win_quickpanel_priority_minor_get(&ret));
5322 _quickpanel_priority_minor_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5324 int *ret = va_arg(*list, int *);
5325 Elm_Win_Smart_Data *sd = _pd;
5328 #ifdef HAVE_ELEMENTARY_X
5329 _elm_win_xwindow_get(sd);
5331 *ret = ecore_x_e_illume_quickpanel_priority_minor_get(sd->x.xwin);
5336 elm_win_quickpanel_zone_set(Evas_Object *obj,
5340 eo_do(obj, elm_obj_win_quickpanel_zone_set(zone));
5344 _quickpanel_zone_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5346 int zone = va_arg(*list, int);
5347 Elm_Win_Smart_Data *sd = _pd;
5349 #ifdef HAVE_ELEMENTARY_X
5350 _elm_win_xwindow_get(sd);
5352 ecore_x_e_illume_quickpanel_zone_set(sd->x.xwin, zone);
5359 elm_win_quickpanel_zone_get(const Evas_Object *obj)
5361 ELM_WIN_CHECK(obj) 0;
5363 eo_do((Eo *) obj, elm_obj_win_quickpanel_zone_get(&ret));
5368 _quickpanel_zone_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5370 int *ret = va_arg(*list, int *);
5371 Elm_Win_Smart_Data *sd = _pd;
5374 #ifdef HAVE_ELEMENTARY_X
5375 _elm_win_xwindow_get(sd);
5377 *ret = ecore_x_e_illume_quickpanel_zone_get(sd->x.xwin);
5382 elm_win_prop_focus_skip_set(Evas_Object *obj,
5386 eo_do(obj, elm_obj_win_prop_focus_skip_set(skip));
5390 _prop_focus_skip_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5392 Eina_Bool skip = va_arg(*list, int);
5393 Elm_Win_Smart_Data *sd = _pd;
5395 sd->skip_focus = skip;
5396 TRAP(sd, focus_skip_set, skip);
5400 elm_win_illume_command_send(Evas_Object *obj,
5401 Elm_Illume_Command command,
5405 eo_do(obj, elm_obj_win_illume_command_send(command, params));
5409 _illume_command_send(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5411 Elm_Illume_Command command = va_arg(*list, Elm_Illume_Command);
5412 void *params = va_arg(*list, void *);
5414 Elm_Win_Smart_Data *sd = _pd;
5416 #ifdef HAVE_ELEMENTARY_X
5417 _elm_win_xwindow_get(sd);
5422 case ELM_ILLUME_COMMAND_FOCUS_BACK:
5423 ecore_x_e_illume_focus_back_send(sd->x.xwin);
5426 case ELM_ILLUME_COMMAND_FOCUS_FORWARD:
5427 ecore_x_e_illume_focus_forward_send(sd->x.xwin);
5430 case ELM_ILLUME_COMMAND_FOCUS_HOME:
5431 ecore_x_e_illume_focus_home_send(sd->x.xwin);
5434 case ELM_ILLUME_COMMAND_CLOSE:
5435 ecore_x_e_illume_close_send(sd->x.xwin);
5448 elm_win_inlined_image_object_get(Evas_Object *obj)
5450 ELM_WIN_CHECK(obj) NULL;
5451 Evas_Object *ret = NULL;
5452 eo_do(obj, elm_obj_win_inlined_image_object_get(&ret));
5457 _inlined_image_object_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5459 Evas_Object **ret = va_arg(*list, Evas_Object **);
5460 Elm_Win_Smart_Data *sd = _pd;
5465 elm_win_focus_highlight_enabled_set(Evas_Object *obj,
5469 eo_do(obj, elm_obj_win_focus_highlight_enabled_set(enabled));
5473 _focus_highlight_enabled_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5475 Eina_Bool enabled = va_arg(*list, int);
5476 Elm_Win_Smart_Data *sd = _pd;
5478 enabled = !!enabled;
5479 if (sd->focus_highlight.enabled == enabled)
5482 sd->focus_highlight.enabled = enabled;
5484 if (sd->focus_highlight.enabled)
5485 _elm_win_focus_highlight_init(sd);
5487 _elm_win_focus_highlight_shutdown(sd);
5491 elm_win_focus_highlight_enabled_get(const Evas_Object *obj)
5493 ELM_WIN_CHECK(obj) EINA_FALSE;
5494 Eina_Bool ret = EINA_FALSE;
5495 eo_do((Eo *) obj, elm_obj_win_focus_highlight_enabled_get(&ret));
5500 _focus_highlight_enabled_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5502 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5503 Elm_Win_Smart_Data *sd = _pd;
5504 *ret = sd->focus_highlight.enabled;
5508 elm_win_focus_highlight_style_set(Evas_Object *obj,
5512 eo_do(obj, elm_obj_win_focus_highlight_style_set(style));
5516 _elm_win_smart_theme(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
5518 Elm_Win_Smart_Data *sd = _pd;
5519 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5520 Eina_Bool int_ret = EINA_FALSE;
5522 if (ret) *ret = EINA_TRUE;
5524 eo_do_super(obj, MY_CLASS, elm_wdg_theme_apply(&int_ret));
5525 if (!int_ret) return;
5527 sd->focus_highlight.theme_changed = EINA_TRUE;
5528 _elm_win_focus_highlight_reconfigure_job_start(sd);
5530 if (ret) *ret = EINA_TRUE;
5534 _focus_highlight_style_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5536 const char *style = va_arg(*list, const char *);
5537 Elm_Win_Smart_Data *sd = _pd;
5539 eina_stringshare_replace(&sd->focus_highlight.style, style);
5540 sd->focus_highlight.theme_changed = EINA_TRUE;
5541 _elm_win_focus_highlight_reconfigure_job_start(sd);
5545 elm_win_focus_highlight_style_get(const Evas_Object *obj)
5547 ELM_WIN_CHECK(obj) NULL;
5548 const char *ret = NULL;
5549 eo_do((Eo *) obj, elm_obj_win_focus_highlight_style_get(&ret));
5554 _focus_highlight_style_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5556 const char **ret = va_arg(*list, const char **);
5557 Elm_Win_Smart_Data *sd = _pd;
5558 *ret = sd->focus_highlight.style;
5562 elm_win_focus_highlight_animate_set(Evas_Object *obj,
5566 eo_do(obj, elm_obj_win_focus_highlight_animate_set(animate));
5570 _focus_highlight_animate_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5572 Eina_Bool animate = va_arg(*list, int);
5573 Elm_Win_Smart_Data *sd = _pd;
5575 animate = !!animate;
5576 if (sd->focus_highlight.animate == animate)
5579 sd->focus_highlight.animate = animate;
5580 sd->focus_highlight.theme_changed = EINA_TRUE;
5581 _elm_win_focus_highlight_reconfigure_job_start(sd);
5585 elm_win_focus_highlight_animate_get(const Evas_Object *obj)
5587 ELM_WIN_CHECK(obj) EINA_FALSE;
5588 Eina_Bool ret = EINA_FALSE;
5589 eo_do((Eo *) obj, elm_obj_win_focus_highlight_animate_get(&ret));
5594 _focus_highlight_animate_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5596 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5597 Elm_Win_Smart_Data *sd = _pd;
5598 *ret = sd->focus_highlight.animate;
5602 elm_win_socket_listen(Evas_Object *obj,
5603 const char *svcname,
5607 ELM_WIN_CHECK(obj) EINA_FALSE;
5608 Eina_Bool ret = EINA_FALSE;
5609 eo_do(obj, elm_obj_win_socket_listen(svcname, svcnum, svcsys, &ret));
5614 _socket_listen(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5616 const char *svcname = va_arg(*list, const char *);
5617 int svcnum = va_arg(*list, int);
5618 Eina_Bool svcsys = va_arg(*list, int);
5619 Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5620 Elm_Win_Smart_Data *sd = _pd;
5623 if (!sd->ee) return;
5625 if (!ecore_evas_extn_socket_listen(sd->ee, svcname, svcnum, svcsys))
5631 /* windowing specific calls - shall we do this differently? */
5634 elm_win_xwindow_get(const Evas_Object *obj)
5638 if (!evas_object_smart_type_check_ptr(obj, MY_CLASS_NAME_LEGACY))
5640 Ecore_Evas *ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
5641 return _elm_ee_xwin_get(ee);
5644 ELM_WIN_CHECK(obj) 0;
5645 Ecore_X_Window ret = 0;
5646 eo_do((Eo *) obj, elm_obj_win_xwindow_get(&ret));
5651 _xwindow_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5653 Ecore_X_Window *ret = va_arg(*list, Ecore_X_Window *);
5654 Elm_Win_Smart_Data *sd = _pd;
5656 #ifdef HAVE_ELEMENTARY_X
5664 *ret = elm_win_xwindow_get(sd->parent);
5671 EAPI Ecore_Wl_Window *
5672 elm_win_wl_window_get(const Evas_Object *obj)
5674 if (!obj) return NULL;
5676 if ((!ENGINE_COMPARE(ELM_WAYLAND_SHM)) &&
5677 (!ENGINE_COMPARE(ELM_WAYLAND_EGL)))
5680 if (!evas_object_smart_type_check_ptr(obj, MY_CLASS_NAME_LEGACY))
5682 Ecore_Evas *ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
5683 return _elm_ee_wlwin_get(ee);
5686 ELM_WIN_CHECK(obj) NULL;
5687 Ecore_Wl_Window *ret = NULL;
5688 eo_do((Eo *) obj, elm_obj_win_wl_window_get(&ret));
5693 _wl_window_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5695 Ecore_Wl_Window **ret = va_arg(*list, Ecore_Wl_Window **);
5696 #if HAVE_ELEMENTARY_WAYLAND
5697 Elm_Win_Smart_Data *sd = _pd;
5705 *ret = elm_win_wl_window_get(sd->parent);
5715 elm_win_trap_set(const Elm_Win_Trap *t)
5717 DBG("old %p, new %p", trap, t);
5719 if ((t) && (t->version != ELM_WIN_TRAP_VERSION))
5721 CRI("trying to set a trap version %lu while %lu was expected!",
5722 t->version, ELM_WIN_TRAP_VERSION);
5731 elm_win_floating_mode_set(Evas_Object *obj, Eina_Bool floating)
5734 ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
5736 floating = !!floating;
5737 if (floating == sd->floating) return;
5738 sd->floating = floating;
5739 #ifdef HAVE_ELEMENTARY_X
5740 _elm_win_xwindow_get(sd);
5744 ecore_x_e_illume_window_state_set
5745 (sd->x.xwin, ECORE_X_ILLUME_WINDOW_STATE_FLOATING);
5747 ecore_x_e_illume_window_state_set
5748 (sd->x.xwin, ECORE_X_ILLUME_WINDOW_STATE_NORMAL);
5754 elm_win_floating_mode_get(const Evas_Object *obj)
5756 ELM_WIN_CHECK(obj) EINA_FALSE;
5757 ELM_WIN_DATA_GET_OR_RETURN_VAL(obj, sd, EINA_FALSE);
5759 return sd->floating;
5763 _window_id_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5765 Ecore_Window *ret = va_arg(*list, Ecore_Window *);
5766 Elm_Win_Smart_Data *sd = _pd;
5768 if ((ENGINE_COMPARE(ELM_WAYLAND_SHM)) || (ENGINE_COMPARE(ELM_WAYLAND_EGL)))
5770 #if HAVE_ELEMENTARY_WAYLAND
5773 *ret = (Ecore_Window)ecore_wl_window_surface_id_get(sd->wl.win);
5778 Ecore_Wl_Window *parent;
5780 parent = elm_win_wl_window_get(sd->parent);
5781 if (parent) *ret = (Ecore_Window)ecore_wl_window_surface_id_get(parent);
5788 #ifdef HAVE_ELEMENTARY_X
5789 _elm_win_xwindow_get(sd);
5792 *ret = (Ecore_Window)sd->x.xwin;
5797 *ret = (Ecore_Window)elm_win_xwindow_get(sd->parent);
5807 elm_win_window_id_get(const Evas_Object *obj)
5811 if (!evas_object_smart_type_check_ptr(obj, MY_CLASS_NAME_LEGACY))
5813 Ecore_Evas *ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
5814 return ecore_evas_window_get(ee);
5817 ELM_WIN_CHECK(obj) 0;
5818 Ecore_Window ret = 0;
5819 eo_do((Eo *) obj, elm_obj_win_window_id_get(&ret));
5824 _class_constructor(Eo_Class *klass)
5826 const Eo_Op_Func_Description func_desc[] = {
5827 EO_OP_FUNC(EO_BASE_ID(EO_BASE_SUB_ID_CONSTRUCTOR), _constructor),
5828 EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_ADD), _elm_win_smart_add),
5829 EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_DEL), _elm_win_smart_del),
5830 EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_RESIZE), _elm_win_smart_resize),
5831 EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_MOVE), _elm_win_smart_move),
5832 EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_SHOW), _elm_win_smart_show),
5833 EO_OP_FUNC(EVAS_OBJ_SMART_ID(EVAS_OBJ_SMART_SUB_ID_HIDE), _elm_win_smart_hide),
5835 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_ON_FOCUS), _elm_win_smart_on_focus),
5836 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_EVENT), _elm_win_smart_event),
5837 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_FOCUS_NEXT_MANAGER_IS), _elm_win_smart_focus_next_manager_is),
5838 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_FOCUS_NEXT), _elm_win_smart_focus_next),
5839 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_FOCUS_DIRECTION_MANAGER_IS), _elm_win_smart_focus_direction_manager_is),
5840 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_FOCUS_DIRECTION), _elm_win_smart_focus_direction),
5841 EO_OP_FUNC(ELM_WIDGET_ID(ELM_WIDGET_SUB_ID_THEME_APPLY), _elm_win_smart_theme),
5843 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WIN_CONSTRUCTOR), _win_constructor),
5844 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_RESIZE_OBJECT_ADD), _resize_object_add),
5845 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_RESIZE_OBJECT_DEL), _resize_object_del),
5846 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_TYPE_GET), _type_get),
5847 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_TITLE_SET), _title_set),
5848 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_TITLE_GET), _title_get),
5849 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ICON_NAME_SET), _icon_name_set),
5850 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ICON_NAME_GET), _icon_name_get),
5851 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ROLE_SET), _role_set),
5852 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ROLE_GET), _role_get),
5853 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ICON_OBJECT_SET), _icon_object_set),
5854 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ICON_OBJECT_GET), _icon_object_get),
5855 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_AUTODEL_SET), _autodel_set),
5856 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_AUTODEL_GET), _autodel_get),
5857 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ACTIVATE), _activate),
5858 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_LOWER), _lower),
5859 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_RAISE), _raise),
5860 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_CENTER), _center),
5861 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_BORDERLESS_SET), _borderless_set),
5862 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_BORDERLESS_GET), _borderless_get),
5863 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SHAPED_SET), _shaped_set),
5864 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SHAPED_GET), _shaped_get),
5865 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ALPHA_SET), _alpha_set),
5866 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ALPHA_GET), _alpha_get),
5867 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_OVERRIDE_SET), _override_set),
5868 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_OVERRIDE_GET), _override_get),
5869 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FULLSCREEN_SET), _fullscreen_set),
5870 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FULLSCREEN_GET), _fullscreen_get),
5871 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_MAIN_MENU_GET), _main_menu_get),
5872 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_MAXIMIZED_SET), _maximized_set),
5873 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_MAXIMIZED_GET), _maximized_get),
5874 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ICONIFIED_SET), _iconified_set),
5875 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ICONIFIED_GET), _iconified_get),
5876 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WITHDRAWN_SET), _withdrawn_set),
5877 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WITHDRAWN_GET), _withdrawn_get),
5878 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_AVAILABLE_PROFILES_SET), _available_profiles_set),
5879 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_AVAILABLE_PROFILES_GET), _available_profiles_get),
5880 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_PROFILE_SET), _profile_set),
5881 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_PROFILE_GET), _profile_get),
5882 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_URGENT_SET), _urgent_set),
5883 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_URGENT_GET), _urgent_get),
5884 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_DEMAND_ATTENTION_SET), _demand_attention_set),
5885 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_DEMAND_ATTENTION_GET), _demand_attention_get),
5886 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_MODAL_SET), _modal_set),
5887 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_MODAL_GET), _modal_get),
5888 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ASPECT_SET), _aspect_set),
5889 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ASPECT_GET), _aspect_get),
5890 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SIZE_BASE_SET), _size_base_set),
5891 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SIZE_BASE_GET), _size_base_get),
5892 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SIZE_STEP_SET), _size_step_set),
5893 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SIZE_STEP_GET), _size_step_get),
5894 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_LAYER_SET), _layer_set),
5895 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_LAYER_GET), _layer_get),
5896 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ROTATION_SET), _rotation_set),
5897 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ROTATION_WITH_RESIZE_SET), _rotation_with_resize_set),
5898 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ROTATION_GET), _rotation_get),
5899 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_STICKY_SET), _sticky_set),
5900 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_STICKY_GET), _sticky_get),
5901 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_KEYBOARD_MODE_SET), _keyboard_mode_set),
5902 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_KEYBOARD_MODE_GET), _keyboard_mode_get),
5903 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_KEYBOARD_WIN_SET), _keyboard_win_set),
5904 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_KEYBOARD_WIN_GET), _keyboard_win_get),
5905 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_INDICATOR_MODE_SET), _indicator_mode_set),
5906 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_INDICATOR_MODE_GET), _indicator_mode_get),
5907 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_INDICATOR_OPACITY_SET), _indicator_opacity_set),
5908 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_INDICATOR_OPACITY_GET), _indicator_opacity_get),
5909 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SCREEN_POSITION_GET), _screen_position_get),
5910 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_GET), _focus_get),
5911 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SCREEN_CONSTRAIN_SET), _screen_constrain_set),
5912 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SCREEN_CONSTRAIN_GET), _screen_constrain_get),
5913 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SCREEN_SIZE_GET), _screen_size_get),
5914 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SCREEN_DPI_GET), _screen_dpi_get),
5915 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_CONFORMANT_SET), _conformant_set),
5916 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_CONFORMANT_GET), _conformant_get),
5917 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_SET), _quickpanel_set),
5918 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_GET), _quickpanel_get),
5919 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MAJOR_SET), _quickpanel_priority_major_set),
5920 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MAJOR_GET), _quickpanel_priority_major_get),
5921 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MINOR_SET), _quickpanel_priority_minor_set),
5922 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MINOR_GET), _quickpanel_priority_minor_get),
5923 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_ZONE_SET), _quickpanel_zone_set),
5924 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_ZONE_GET), _quickpanel_zone_get),
5925 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_PROP_FOCUS_SKIP_SET), _prop_focus_skip_set),
5926 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_ILLUME_COMMAND_SEND), _illume_command_send),
5927 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_INLINED_IMAGE_OBJECT_GET), _inlined_image_object_get),
5928 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ENABLED_SET), _focus_highlight_enabled_set),
5929 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ENABLED_GET), _focus_highlight_enabled_get),
5930 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_STYLE_SET), _focus_highlight_style_set),
5931 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_STYLE_GET), _focus_highlight_style_get),
5932 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ANIMATE_SET), _focus_highlight_animate_set),
5933 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ANIMATE_GET), _focus_highlight_animate_get),
5934 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_SOCKET_LISTEN), _socket_listen),
5935 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_XWINDOW_GET), _xwindow_get),
5936 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WL_WINDOW_GET), _wl_window_get),
5937 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WINDOW_ID_GET), _window_id_get),
5938 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_ROTATION_SUPPORTED_GET), _wm_rotation_supported_get),
5939 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_PREFERRED_ROTATION_SET), _wm_preferred_rotation_set),
5940 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_PREFERRED_ROTATION_GET), _wm_preferred_rotation_get),
5941 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_AVAILABLE_ROTATIONS_SET), _wm_available_rotations_set),
5942 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_AVAILABLE_ROTATIONS_GET), _wm_available_rotations_get),
5943 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_MANUAL_ROTATION_DONE_SET), _wm_manual_rotation_done_set),
5944 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_MANUAL_ROTATION_DONE_GET), _wm_manual_rotation_done_get),
5945 EO_OP_FUNC(ELM_OBJ_WIN_ID(ELM_OBJ_WIN_SUB_ID_WM_MANUAL_ROTATION_DONE), _wm_manual_rotation_done),
5950 eo_class_funcs_set(klass, func_desc);
5952 evas_smart_legacy_type_register(MY_CLASS_NAME_LEGACY, klass);
5955 static const Eo_Op_Description op_desc[] = {
5956 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WIN_CONSTRUCTOR, "Adds a window object."),
5957 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_RESIZE_OBJECT_ADD, "Add subobj as a resize object of window obj."),
5958 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_RESIZE_OBJECT_DEL, "Delete subobj as a resize object of window obj."),
5959 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_TYPE_GET, "Get the type of the window."),
5960 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_TITLE_SET, "Set the title of the window."),
5961 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_TITLE_GET, "Get the title of the window."),
5962 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ICON_NAME_SET, "Set the icon name of the window."),
5963 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ICON_NAME_GET, "Get the icon name of the window."),
5964 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ROLE_SET, "Set the role of the window."),
5965 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ROLE_GET, "Get the role of the window."),
5966 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ICON_OBJECT_SET, "Set a window object's icon."),
5967 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ICON_OBJECT_GET, "Get the icon object used for the window."),
5968 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_AUTODEL_SET, "Set the window's autodel state."),
5969 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_AUTODEL_GET, "Get the window's autodel state."),
5970 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ACTIVATE, "Activate a window object."),
5971 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_LOWER, "Lower a window object."),
5972 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_RAISE, "Raise a window object."),
5973 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_CENTER, "Center a window on its screen."),
5974 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_BORDERLESS_SET, "Set the borderless state of a window."),
5975 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_BORDERLESS_GET, "Get the borderless state of a window."),
5976 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SHAPED_SET, "Set the shaped state of a window."),
5977 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SHAPED_GET, "Get the shaped state of a window."),
5978 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ALPHA_SET, "Set the alpha channel state of a window."),
5979 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ALPHA_GET, "Get the alpha channel state of a window."),
5980 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_OVERRIDE_SET, "Set the override state of a window."),
5981 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_OVERRIDE_GET, "Get the override state of a window."),
5982 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FULLSCREEN_SET, "Set the fullscreen state of a window."),
5983 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FULLSCREEN_GET, "Get the fullscreen state of a window."),
5984 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_MAIN_MENU_GET, "Get the Main Menu of a window."),
5985 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_MAXIMIZED_SET, "Set the maximized state of a window."),
5986 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_MAXIMIZED_GET, "Get the maximized state of a window."),
5987 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ICONIFIED_SET, "Set the iconified state of a window."),
5988 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ICONIFIED_GET, "Get the iconified state of a window."),
5989 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WITHDRAWN_SET, "Set the withdrawn state of a window."),
5990 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WITHDRAWN_GET, "Get the withdrawn state of a window."),
5991 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_AVAILABLE_PROFILES_SET, "Set the array of available profiles to a window."),
5992 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_AVAILABLE_PROFILES_GET, "Get the array of available profiles of a window."),
5993 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_PROFILE_SET, "Set the profile of a window."),
5994 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_PROFILE_GET, "Get the profile of a window."),
5995 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_URGENT_SET, "Set the urgent state of a window."),
5996 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_URGENT_GET, "Get the urgent state of a window."),
5997 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_DEMAND_ATTENTION_SET, "Set the demand_attention state of a window."),
5998 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_DEMAND_ATTENTION_GET, "Get the demand_attention state of a window."),
5999 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_MODAL_SET, "Set the modal state of a window."),
6000 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_MODAL_GET, "Get the modal state of a window."),
6001 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ASPECT_SET, "Set the aspect ratio of a window."),
6002 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ASPECT_GET, "Get the aspect ratio of a window."),
6003 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SIZE_BASE_SET, "Set the base window size used with stepping calculation."),
6004 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SIZE_BASE_GET, "Get the base size of a window."),
6005 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SIZE_STEP_SET, "Set the window stepping used with sizing calculation."),
6006 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SIZE_STEP_GET, "Get the stepping of a window."),
6007 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_LAYER_SET, "Set the layer of the window."),
6008 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_LAYER_GET, "Get the layer of the window."),
6009 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ROTATION_SET, "Set the rotation of the window."),
6010 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ROTATION_WITH_RESIZE_SET, "Rotates the window and resizes it."),
6011 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ROTATION_GET, "Get the rotation of the window."),
6012 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_STICKY_SET, "Set the sticky state of the window."),
6013 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_STICKY_GET, "Get the sticky state of the window."),
6014 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_KEYBOARD_MODE_SET, "Sets the keyboard mode of the window."),
6015 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_KEYBOARD_MODE_GET, "Get the keyboard mode of the window."),
6016 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_KEYBOARD_WIN_SET, "Sets whether the window is a keyboard."),
6017 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_KEYBOARD_WIN_GET, "Get whether the window is a keyboard."),
6018 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_INDICATOR_MODE_SET, "Sets the indicator mode of the window."),
6019 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_INDICATOR_MODE_GET, "Get the indicator mode of the window."),
6020 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_INDICATOR_OPACITY_SET, "Sets the indicator opacity mode of the window."),
6021 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_INDICATOR_OPACITY_GET, "Get the indicator opacity mode of the window."),
6022 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SCREEN_POSITION_GET, "Get the screen position of a window."),
6023 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_GET, "Determine whether a window has focus."),
6024 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SCREEN_CONSTRAIN_SET, "Constrain the maximum width and height of a window to the width and height of its screen."),
6025 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SCREEN_CONSTRAIN_GET, "Retrieve the constraints on the maximum width and height of a window relative to the width and height of its screen."),
6026 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SCREEN_SIZE_GET, "Get screen geometry details for the screen that a window is on."),
6027 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SCREEN_DPI_GET, "Get screen dpi for the screen that a window is on."),
6028 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_CONFORMANT_SET, "Set if this window is an illume conformant window."),
6029 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_CONFORMANT_GET, "Get if this window is an illume conformant window."),
6030 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_SET, "Set a window to be an illume quickpanel window."),
6031 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_GET, "Get if this window is a quickpanel or not."),
6032 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MAJOR_SET, "Set the major priority of a quickpanel window."),
6033 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MAJOR_GET, "Get the major priority of a quickpanel window."),
6034 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MINOR_SET, "Set the minor priority of a quickpanel window."),
6035 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_PRIORITY_MINOR_GET, "Get the minor priority of a quickpanel window."),
6036 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_ZONE_SET, "Set which zone this quickpanel should appear in."),
6037 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_QUICKPANEL_ZONE_GET, "Get which zone this quickpanel should appear in."),
6038 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_PROP_FOCUS_SKIP_SET, "Set the window to be skipped by keyboard focus."),
6039 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_ILLUME_COMMAND_SEND, "Send a command to the windowing environment."),
6040 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_INLINED_IMAGE_OBJECT_GET, "Get the inlined image object handle."),
6041 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ENABLED_SET, "Set the enabled status for the focus highlight in a window."),
6042 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ENABLED_GET, "Get the enabled value of the focus highlight for this window."),
6043 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_STYLE_SET, "Set the style for the focus highlight on this window."),
6044 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_STYLE_GET, "Get the style set for the focus highlight object."),
6045 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ANIMATE_SET, "Set the animate status for the focus highlight for this window."),
6046 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_FOCUS_HIGHLIGHT_ANIMATE_GET, "Get the animate status for the focus highlight for this window."),
6047 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_SOCKET_LISTEN, "Create a socket to provide the service for Plug widget."),
6048 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_XWINDOW_GET, "Get the Ecore_X_Window of an Evas_Object."),
6049 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WL_WINDOW_GET, "Get the Ecore_Wl_Window of an Evas_Object."),
6050 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WINDOW_ID_GET, "Get the Ecore_Window of an Evas_Object."),
6051 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_ROTATION_SUPPORTED_GET, "Query if the underlying windowing system supports the window manager rotation.."),
6052 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_PREFERRED_ROTATION_SET, "Set the preferred rotation hint."),
6053 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_PREFERRED_ROTATION_GET, "Get the preferred rotation hint."),
6054 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_AVAILABLE_ROTATIONS_SET, "Set the array of available window rotations."),
6055 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_AVAILABLE_ROTATIONS_GET, "Get the array of available window rotations."),
6056 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_MANUAL_ROTATION_DONE_SET, "Set manual rotation done mode of obj window."),
6057 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_MANUAL_ROTATION_DONE_GET, "Get manual rotation done mode of obj window."),
6058 EO_OP_DESCRIPTION(ELM_OBJ_WIN_SUB_ID_WM_MANUAL_ROTATION_DONE, "Set rotation finish manually"),
6059 EO_OP_DESCRIPTION_SENTINEL
6062 static const Eo_Class_Description class_desc = {
6065 EO_CLASS_TYPE_REGULAR,
6066 EO_CLASS_DESCRIPTION_OPS(&ELM_OBJ_WIN_BASE_ID, op_desc, ELM_OBJ_WIN_SUB_ID_LAST),
6068 sizeof(Elm_Win_Smart_Data),
6073 EO_DEFINE_CLASS(elm_obj_win_class_get, &class_desc, ELM_OBJ_WIDGET_CLASS, NULL);