elm: fixed up the comments after the struct member.
[platform/upstream/elementary.git] / src / lib / elm_win.c
1 #ifdef HAVE_CONFIG_H
2 # include "elementary_config.h"
3 #endif
4
5 #include <Elementary.h>
6 #include <Elementary_Cursor.h>
7
8 #include "elm_priv.h"
9 #include "elm_widget_menu.h"
10
11 EAPI Eo_Op ELM_OBJ_WIN_BASE_ID = EO_NOOP;
12
13 #define MY_CLASS ELM_OBJ_WIN_CLASS
14
15 #define MY_CLASS_NAME "Elm_Win"
16 #define MY_CLASS_NAME_LEGACY "elm_win"
17
18 static const Elm_Win_Trap *trap = NULL;
19
20 #define TRAP(sd, name, ...)                                             \
21   do                                                                    \
22     {                                                                   \
23        if ((!trap) || (!trap->name) ||                                  \
24            ((trap->name) &&                                             \
25             (trap->name(sd->trap_data, sd->obj, ## __VA_ARGS__)))) \
26          ecore_evas_##name(sd->ee, ##__VA_ARGS__);                      \
27     }                                                                   \
28   while (0)
29
30 #define ELM_WIN_DATA_GET(o, sd) \
31   Elm_Win_Smart_Data * sd = eo_data_scope_get(o, MY_CLASS)
32
33 #define ELM_WIN_DATA_GET_OR_RETURN(o, ptr)           \
34   ELM_WIN_DATA_GET(o, ptr);                          \
35   if (!ptr)                                          \
36     {                                                \
37        CRI("No widget data for object %p (%s)", \
38                 o, evas_object_type_get(o));         \
39        return;                                       \
40     }
41
42 #define ELM_WIN_DATA_GET_OR_RETURN_VAL(o, ptr, val)  \
43   ELM_WIN_DATA_GET(o, ptr);                          \
44   if (!ptr)                                          \
45     {                                                \
46        CRI("No widget data for object %p (%s)", \
47                 o, evas_object_type_get(o));         \
48        return val;                                   \
49     }
50
51 #define ELM_WIN_CHECK(obj)                                             \
52   if (!obj || !eo_isa(obj, MY_CLASS)) \
53     return
54
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))
57
58 typedef struct _Elm_Win_Smart_Data Elm_Win_Smart_Data;
59
60 struct _Elm_Win_Smart_Data
61 {
62    Ecore_Evas           *ee;
63    Evas                 *evas;
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;
68    Eo                   *layout;
69    Eo                   *box;
70    Evas_Object          *obj; /* The object itself */
71 #ifdef HAVE_ELEMENTARY_X
72    struct
73    {
74       Ecore_X_Window       xwin;
75       Ecore_Event_Handler *client_message_handler;
76       Ecore_Event_Handler *property_handler;
77    } x;
78 #endif
79 #ifdef HAVE_ELEMENTARY_WAYLAND
80    struct
81    {
82       Ecore_Wl_Window *win;
83    } wl;
84 #endif
85
86    Ecore_Job                     *deferred_resize_job;
87    Ecore_Job                     *deferred_child_eval_job;
88
89    Elm_Win_Type                   type;
90    Elm_Win_Keyboard_Mode          kbdmode;
91    Elm_Win_Indicator_Mode         indmode;
92    Elm_Win_Indicator_Opacity_Mode ind_o_mode;
93    struct
94    {
95       const char  *info;
96       Ecore_Timer *timer;
97       int          repeat_count;
98       int          shot_counter;
99    } shot;
100    int                            resize_location;
101    int                           *autodel_clear, rot;
102    struct
103    {
104       int x, y;
105    } screen;
106    struct
107    {
108       Ecore_Evas  *ee;
109       Evas        *evas;
110       Evas_Object *obj, *hot_obj;
111       int          hot_x, hot_y;
112    } pointer;
113    struct
114    {
115       Evas_Object *fobj; /* focus highlight edje object */
116
117       struct
118       {
119          Evas_Object *target;
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. */
123       } cur, prev;
124
125       const char  *style;
126       Ecore_Job   *reconf_job;
127
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;
133    } focus_highlight;
134
135    Evas_Object *icon;
136    const char  *title;
137    const char  *icon_name;
138    const char  *role;
139
140    Evas_Object *main_menu;
141
142    struct
143    {
144       const char  *name;
145       const char **available_list;
146       unsigned int count;
147    } profile;
148    struct
149    {
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. */
155    } wm_rot;
156
157    void *trap_data;
158
159    double       aspect;
160    int          size_base_w, size_base_h;
161    int          size_step_w, size_step_h;
162    int          norender;
163    Eina_Bool    urgent : 1;
164    Eina_Bool    modal : 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;
176 };
177
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";
198
199 static const Evas_Smart_Cb_Description _smart_callbacks[] = {
200    {SIG_DELETE_REQUEST, ""},
201    {SIG_FOCUS_OUT, ""},
202    {SIG_FOCUS_IN, ""},
203    {SIG_MOVED, ""},
204    {SIG_WITHDRAWN, ""},
205    {SIG_ICONIFIED, ""},
206    {SIG_NORMAL, ""},
207    {SIG_STICK, ""},
208    {SIG_UNSTICK, ""},
209    {SIG_FULLSCREEN, ""},
210    {SIG_UNFULLSCREEN, ""},
211    {SIG_MAXIMIZED, ""},
212    {SIG_UNMAXIMIZED, ""},
213    {SIG_IOERR, ""},
214    {SIG_INDICATOR_PROP_CHANGED, ""},
215    {SIG_ROTATION_CHANGED, ""},
216    {SIG_PROFILE_CHANGED, ""},
217    {SIG_FOCUSED, ""},
218    {SIG_UNFOCUSED, ""},
219    {SIG_WM_ROTATION_CHANGED, ""},
220    {NULL, NULL}
221 };
222
223 Eina_List *_elm_win_list = NULL;
224 int _elm_win_deferred_free = 0;
225
226 static int _elm_win_count = 0;
227
228 static Eina_Bool _elm_win_auto_throttled = EINA_FALSE;
229
230 static Ecore_Job *_elm_win_state_eval_job = NULL;
231
232 static void
233 _elm_win_on_resize_obj_changed_size_hints(void *data,
234                                           Evas *e,
235                                           Evas_Object *obj,
236                                           void *event_info);
237 #ifdef HAVE_ELEMENTARY_X
238 static void _elm_win_xwin_update(Elm_Win_Smart_Data *sd);
239 #endif
240
241 EAPI double _elm_startup_time = 0;
242
243 static void
244 _elm_win_first_frame_do(void *data, Evas *e EINA_UNUSED, void *event_info EINA_UNUSED)
245 {
246    double end = ecore_time_unix_get();
247    char *first = data;
248
249    switch (*first)
250      {
251       case 'A': abort();
252       case 'E':
253       case 'D': exit(-1);
254       case 'T': fprintf(stderr, "Startup time: '%f' - '%f' = '%f' sec\n", end, _elm_startup_time, end - _elm_startup_time);
255                 break;
256      }
257
258    evas_event_callback_del_full(e, EVAS_CALLBACK_RENDER_POST, _elm_win_first_frame_do, data);
259 }
260
261 static void
262 _elm_win_state_eval(void *data EINA_UNUSED)
263 {
264    Eina_List *l;
265    Evas_Object *obj;
266    int _elm_win_count_shown = 0;
267    int _elm_win_count_iconified = 0;
268    int _elm_win_count_withdrawn = 0;
269
270    _elm_win_state_eval_job = NULL;
271
272    if (_elm_config->auto_norender_withdrawn)
273      {
274         EINA_LIST_FOREACH(_elm_win_list, l, obj)
275           {
276              if ((elm_win_withdrawn_get(obj)) ||
277                  ((elm_win_iconified_get(obj) &&
278                    (_elm_config->auto_norender_iconified_same_as_withdrawn))))
279                {
280                   if (!evas_object_data_get(obj, "__win_auto_norender"))
281                     {
282                        Evas *evas = evas_object_evas_get(obj);
283
284                        elm_win_norender_push(obj);
285                        evas_object_data_set(obj, "__win_auto_norender", obj);
286
287                        if (_elm_config->auto_flush_withdrawn)
288                          {
289                             edje_file_cache_flush();
290                             edje_collection_cache_flush();
291                             evas_image_cache_flush(evas);
292                             evas_font_cache_flush(evas);
293                          }
294                        if (_elm_config->auto_dump_withdrawn)
295                          {
296                             evas_render_dump(evas);
297                          }
298                     }
299                }
300              else
301                {
302                   if (evas_object_data_get(obj, "__win_auto_norender"))
303                     {
304                        elm_win_norender_pop(obj);
305                        evas_object_data_del(obj, "__win_auto_norender");
306                     }
307                }
308           }
309      }
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))
313      {
314         if (_elm_win_count == 0)
315           {
316              if (_elm_win_auto_throttled)
317                {
318                   ecore_throttle_adjust(-_elm_config->auto_throttle_amount);
319                   _elm_win_auto_throttled = EINA_FALSE;
320                }
321           }
322         else
323           {
324              EINA_LIST_FOREACH(_elm_win_list, l, obj)
325                {
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++;
332                }
333              if (_elm_win_count_shown <= 0)
334                {
335                   if (!_elm_win_auto_throttled)
336                     {
337                        ecore_throttle_adjust(_elm_config->auto_throttle_amount);
338                        _elm_win_auto_throttled = EINA_TRUE;
339                     }
340                }
341              else
342                {
343                   if (_elm_win_auto_throttled)
344                     {
345                        ecore_throttle_adjust(-_elm_config->auto_throttle_amount);
346                        _elm_win_auto_throttled = EINA_FALSE;
347                     }
348                }
349           }
350      }
351 }
352
353 static void
354 _elm_win_state_eval_queue(void)
355 {
356    ecore_job_del(_elm_win_state_eval_job);
357    _elm_win_state_eval_job = ecore_job_add(_elm_win_state_eval, NULL);
358 }
359
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"
362
363 static double
364 _shot_delay_get(Elm_Win_Smart_Data *sd)
365 {
366    char *p, *pd;
367    char *d = strdup(sd->shot.info);
368
369    if (!d) return 0.5;
370    for (p = (char *)sd->shot.info; *p; p++)
371      {
372         if (!strncmp(p, "delay=", 6))
373           {
374              double v;
375
376              for (pd = d, p += 6; (*p) && (*p != ':'); p++, pd++)
377                {
378                   *pd = *p;
379                }
380              *pd = 0;
381              v = _elm_atof(d);
382              free(d);
383              return v;
384           }
385      }
386    free(d);
387
388    return 0.5;
389 }
390
391 static char *
392 _shot_file_get(Elm_Win_Smart_Data *sd)
393 {
394    char *p;
395    char *tmp = strdup(sd->shot.info);
396    char *repname = NULL;
397
398    if (!tmp) return NULL;
399
400    for (p = (char *)sd->shot.info; *p; p++)
401      {
402         if (!strncmp(p, "file=", 5))
403           {
404              strcpy(tmp, p + 5);
405              if (!sd->shot.repeat_count) return tmp;
406              else
407                {
408                   char *dotptr = strrchr(tmp, '.');
409                   if (dotptr)
410                     {
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);
418                        free(tmp);
419                        return repname;
420                     }
421                }
422           }
423      }
424    free(tmp);
425    if (!sd->shot.repeat_count) return strdup("out.png");
426
427    repname = malloc(sizeof(char) * 24);
428    snprintf(repname, sizeof(char) * 24, "out%03i.png",
429             sd->shot.shot_counter + 1);
430
431    return repname;
432 }
433
434 static int
435 _shot_repeat_count_get(Elm_Win_Smart_Data *sd)
436 {
437    char *p, *pd;
438    char *d = strdup(sd->shot.info);
439
440    if (!d) return 0;
441    for (p = (char *)sd->shot.info; *p; p++)
442      {
443         if (!strncmp(p, "repeat=", 7))
444           {
445              int v;
446
447              for (pd = d, p += 7; (*p) && (*p != ':'); p++, pd++)
448                {
449                   *pd = *p;
450                }
451              *pd = 0;
452              v = atoi(d);
453              if (v < 0) v = 0;
454              if (v > 1000) v = 999;
455              free(d);
456              return v;
457           }
458      }
459    free(d);
460
461    return 0;
462 }
463
464 static char *
465 _shot_key_get(Elm_Win_Smart_Data *sd EINA_UNUSED)
466 {
467    return NULL;
468 }
469
470 static char *
471 _shot_flags_get(Elm_Win_Smart_Data *sd EINA_UNUSED)
472 {
473    return NULL;
474 }
475
476 static void
477 _shot_do(Elm_Win_Smart_Data *sd)
478 {
479    Ecore_Evas *ee;
480    Evas_Object *o;
481    unsigned int *pixels;
482    int w, h;
483    char *file, *key, *flags;
484
485    ecore_evas_manual_render(sd->ee);
486    pixels = (void *)ecore_evas_buffer_pixels_get(sd->ee);
487    if (!pixels) return;
488
489    ecore_evas_geometry_get(sd->ee, NULL, NULL, &w, &h);
490    if ((w < 1) || (h < 1)) return;
491
492    file = _shot_file_get(sd);
493    if (!file) return;
494
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))
503      {
504         ERR("Cannot save window to '%s' (key '%s', flags '%s')",
505             file, key, flags);
506      }
507    free(file);
508    free(key);
509    free(flags);
510    ecore_evas_free(ee);
511    if (sd->shot.repeat_count) sd->shot.shot_counter++;
512 }
513
514 static Eina_Bool
515 _shot_delay(void *data)
516 {
517    ELM_WIN_DATA_GET(data, sd);
518
519    _shot_do(sd);
520    if (sd->shot.repeat_count)
521      {
522         int remainshot = (sd->shot.repeat_count - sd->shot.shot_counter);
523         if (remainshot > 0) return EINA_TRUE;
524      }
525    sd->shot.timer = NULL;
526    elm_exit();
527
528    return EINA_FALSE;
529 }
530
531 static void
532 _shot_init(Elm_Win_Smart_Data *sd)
533 {
534    if (!sd->shot.info) return;
535
536    sd->shot.repeat_count = _shot_repeat_count_get(sd);
537    sd->shot.shot_counter = 0;
538 }
539
540 static void
541 _shot_handle(Elm_Win_Smart_Data *sd)
542 {
543    if (!sd->shot.info) return;
544
545    if (!sd->shot.timer)
546      sd->shot.timer = ecore_timer_add(_shot_delay_get(sd), _shot_delay,
547                                       sd->obj);
548 }
549
550 /* elm-win specific associate, does the trap while ecore_evas_object_associate()
551  * does not.
552  */
553 static Elm_Win_Smart_Data *
554 _elm_win_associate_get(const Ecore_Evas *ee)
555 {
556    ELM_WIN_DATA_GET(ecore_evas_data_get(ee, "elm_win"), sd);
557    return sd;
558 }
559
560 /* Interceptors Callbacks */
561 static void
562 _elm_win_obj_intercept_raise(void *data, Evas_Object *obj EINA_UNUSED)
563 {
564    ELM_WIN_DATA_GET(data, sd);
565    TRAP(sd, raise);
566 }
567
568 static void
569 _elm_win_obj_intercept_lower(void *data, Evas_Object *obj EINA_UNUSED)
570 {
571    ELM_WIN_DATA_GET(data, sd);
572    TRAP(sd, lower);
573 }
574
575 static void
576 _elm_win_obj_intercept_stack_above(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, Evas_Object *above EINA_UNUSED)
577 {
578    INF("TODO: %s", __FUNCTION__);
579 }
580
581 static void
582 _elm_win_obj_intercept_stack_below(void *data EINA_UNUSED, Evas_Object *obj EINA_UNUSED, Evas_Object *below EINA_UNUSED)
583 {
584    INF("TODO: %s", __FUNCTION__);
585 }
586
587 static void
588 _elm_win_obj_intercept_layer_set(void *data, Evas_Object *obj EINA_UNUSED, int l)
589 {
590    ELM_WIN_DATA_GET(data, sd);
591    TRAP(sd, layer_set, l);
592 }
593
594 /* Event Callbacks */
595
596 static void
597 _elm_win_obj_callback_changed_size_hints(void *data, Evas *e EINA_UNUSED, Evas_Object *obj, void *event_info EINA_UNUSED)
598 {
599    ELM_WIN_DATA_GET(data, sd);
600    Evas_Coord w, h;
601
602    evas_object_size_hint_min_get(obj, &w, &h);
603    TRAP(sd, size_min_set, w, h);
604
605    evas_object_size_hint_max_get(obj, &w, &h);
606    if (w < 1) w = -1;
607    if (h < 1) h = -1;
608    TRAP(sd, size_max_set, w, h);
609 }
610 /* end of elm-win specific associate */
611
612 static void
613 _elm_win_move(Ecore_Evas *ee)
614 {
615    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
616    int x, y;
617
618    EINA_SAFETY_ON_NULL_RETURN(sd);
619
620    ecore_evas_geometry_get(ee, &x, &y, NULL, NULL);
621    sd->screen.x = x;
622    sd->screen.y = y;
623    evas_object_smart_callback_call(sd->obj, SIG_MOVED, NULL);
624 }
625
626 static void
627 _elm_win_resize_job(void *data)
628 {
629    ELM_WIN_DATA_GET(data, sd);
630    int w, h;
631
632    sd->deferred_resize_job = NULL;
633    ecore_evas_request_geometry_get(sd->ee, NULL, NULL, &w, &h);
634    if (sd->constrain)
635      {
636         int sw, sh;
637         ecore_evas_screen_geometry_get(sd->ee, NULL, NULL, &sw, &sh);
638         w = MIN(w, sw);
639         h = MIN(h, sh);
640      }
641
642    if (sd->frame_obj)
643      {
644         int fx, fy, fw, fh;
645
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);
649      }
650
651    evas_object_resize(sd->obj, w, h);
652    evas_object_resize(sd->layout, w, h);
653 }
654
655 static void
656 _elm_win_resize(Ecore_Evas *ee)
657 {
658    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
659    EINA_SAFETY_ON_NULL_RETURN(sd);
660
661    ecore_job_del(sd->deferred_resize_job);
662    sd->deferred_resize_job = ecore_job_add(_elm_win_resize_job, sd->obj);
663 }
664
665 static void
666 _elm_win_mouse_in(Ecore_Evas *ee)
667 {
668    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
669    EINA_SAFETY_ON_NULL_RETURN(sd);
670
671    if (sd->resizing) sd->resizing = EINA_FALSE;
672 }
673
674 static void
675 _elm_win_focus_highlight_reconfigure_job_stop(Elm_Win_Smart_Data *sd)
676 {
677    ELM_SAFE_FREE(sd->focus_highlight.reconf_job, ecore_job_del);
678 }
679
680 static void
681 _elm_win_focus_highlight_visible_set(Elm_Win_Smart_Data *sd,
682                                      Eina_Bool visible)
683 {
684    Evas_Object *fobj = sd->focus_highlight.fobj;
685    if (!fobj) return;
686
687    if (visible)
688      {
689         evas_object_show(fobj);
690         edje_object_signal_emit(fobj, "elm,action,focus,show", "elm");
691      }
692    else
693      {
694         edje_object_signal_emit(fobj, "elm,action,focus,hide", "elm");
695      }
696 }
697
698 static void
699 _elm_win_focus_highlight_anim_setup(Elm_Win_Smart_Data *sd,
700                                     Evas_Object *obj)
701 {
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;
707
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);
714
715    m = alloca(sizeof(*m) + (sizeof(int) * 8));
716    m->count = 8;
717    m->val[0] = px - tx;
718    m->val[1] = py - ty;
719    m->val[2] = pw;
720    m->val[3] = ph;
721    m->val[4] = 0;
722    m->val[5] = 0;
723    m->val[6] = tw;
724    m->val[7] = th;
725    edje_object_message_send(obj, EDJE_MESSAGE_INT_SET, 1, m);
726 }
727
728 static void
729 _elm_win_focus_highlight_simple_setup(Elm_Win_Smart_Data *sd,
730                                       Evas_Object *obj)
731 {
732    Evas_Object *clip, *target = sd->focus_highlight.cur.target;
733    Evas_Coord x, y, w, h;
734
735    clip = evas_object_clip_get(target);
736    elm_widget_focus_highlight_geometry_get(target, &x, &y, &w, &h);
737
738    evas_object_move(obj, x, y);
739    evas_object_resize(obj, w, h);
740    if (clip) evas_object_clip_set(obj, clip);
741 }
742
743 static void
744 _elm_win_focus_highlight_reconfigure(Elm_Win_Smart_Data *sd)
745 {
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;
754
755    _elm_win_focus_highlight_reconfigure_job_stop(sd);
756
757    visible_changed = (sd->focus_highlight.cur.visible !=
758                       sd->focus_highlight.prev.visible);
759
760    if ((target == previous) && (!visible_changed) &&
761        (!sd->focus_highlight.geometry_changed) &&
762        (!sd->focus_highlight.theme_changed))
763      return;
764
765    if ((previous) && (sd->focus_highlight.prev.in_theme))
766      elm_widget_signal_emit
767        (previous, "elm,action,focus_highlight,hide", "elm");
768
769    if (!target)
770      common_visible = EINA_FALSE;
771    else if (sd->focus_highlight.cur.in_theme)
772      {
773         common_visible = EINA_FALSE;
774         if (sd->focus_highlight.cur.visible)
775           sig = "elm,action,focus_highlight,show";
776         else
777           sig = "elm,action,focus_highlight,hide";
778      }
779    else
780      common_visible = sd->focus_highlight.cur.visible;
781
782    if (sig)
783      elm_widget_signal_emit(target, sig, "elm");
784
785    if ((!target) || (!common_visible) || (sd->focus_highlight.cur.in_theme))
786      goto the_end;
787
788    if (previous)
789      focus_style_previous = elm_widget_focus_highlight_style_get(previous);
790    focus_style_target = elm_widget_focus_highlight_style_get(target);
791
792    if (sd->focus_highlight.theme_changed ||
793        (focus_style_target != focus_style_previous))
794      {
795         const char *str;
796
797         if (focus_style_target)
798           str = focus_style_target;
799         else if (sd->focus_highlight.style)
800           str = sd->focus_highlight.style;
801         else
802           str = "default";
803
804         elm_widget_theme_object_set
805           (sd->obj, fobj, "focus_highlight", "top", str);
806         sd->focus_highlight.theme_changed = EINA_FALSE;
807
808         if (sd->focus_highlight.animate)
809           {
810              str = edje_object_data_get(sd->focus_highlight.fobj, "animate");
811              sd->focus_highlight.animate_supported = ((str) && (!strcmp(str, "on")));
812           }
813         else
814           sd->focus_highlight.animate_supported = EINA_FALSE;
815      }
816
817    if ((sd->focus_highlight.animate_supported) && (previous) &&
818        (!sd->focus_highlight.prev.in_theme))
819      _elm_win_focus_highlight_anim_setup(sd, fobj);
820    else
821      _elm_win_focus_highlight_simple_setup(sd, fobj);
822    evas_object_raise(fobj);
823
824 the_end:
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;
828 }
829
830 static void
831 _elm_win_focus_highlight_reconfigure_job(void *data)
832 {
833    ELM_WIN_DATA_GET(data, sd);
834    _elm_win_focus_highlight_reconfigure(sd);
835 }
836
837 static void
838 _elm_win_focus_highlight_reconfigure_job_start(Elm_Win_Smart_Data *sd)
839 {
840    ecore_job_del(sd->focus_highlight.reconf_job);
841
842    sd->focus_highlight.reconf_job = ecore_job_add(
843        _elm_win_focus_highlight_reconfigure_job, sd->obj);
844 }
845
846 static void
847 _elm_win_focus_in(Ecore_Evas *ee)
848 {
849    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
850    Evas_Object *obj;
851    unsigned int order = 0;
852
853    EINA_SAFETY_ON_NULL_RETURN(sd);
854
855    obj = sd->obj;
856
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)))
860      {
861         elm_widget_focus_steal(obj);
862      }
863    else
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);
869    if (sd->frame_obj)
870      {
871         edje_object_signal_emit(sd->frame_obj, "elm,action,focus", "elm");
872      }
873
874    /* do nothing */
875    /* else if (sd->img_obj) */
876    /*   { */
877    /*   } */
878 }
879
880 static void
881 _elm_win_focus_out(Ecore_Evas *ee)
882 {
883    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
884    Evas_Object *obj;
885
886    EINA_SAFETY_ON_NULL_RETURN(sd);
887
888    obj = sd->obj;
889
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);
896    if (sd->frame_obj)
897      {
898         edje_object_signal_emit(sd->frame_obj, "elm,action,unfocus", "elm");
899      }
900
901    /* access */
902    _elm_access_object_highlight_disable(evas_object_evas_get(obj));
903
904    /* do nothing */
905    /* if (sd->img_obj) */
906    /*   { */
907    /*   } */
908 }
909
910 static void
911 _elm_win_available_profiles_del(Elm_Win_Smart_Data *sd)
912 {
913    if (!sd->profile.available_list) return;
914
915    unsigned int i;
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);
920 }
921
922 static void
923 _elm_win_profile_del(Elm_Win_Smart_Data *sd)
924 {
925    ELM_SAFE_FREE(sd->profile.name, eina_stringshare_del);
926 }
927
928 static Eina_Bool
929 _elm_win_profile_set(Elm_Win_Smart_Data *sd, const char *profile)
930 {
931    Eina_Bool changed = EINA_FALSE;
932    if (profile)
933      {
934         if (sd->profile.name)
935           {
936              if (strcmp(sd->profile.name, profile) != 0)
937                {
938                   eina_stringshare_replace(&(sd->profile.name), profile);
939                   changed = EINA_TRUE;
940                }
941           }
942         else
943           {
944              sd->profile.name = eina_stringshare_add(profile);
945              changed = EINA_TRUE;
946           }
947      }
948    else
949      _elm_win_profile_del(sd);
950
951    return changed;
952 }
953
954 static void
955 _elm_win_profile_update(Elm_Win_Smart_Data *sd)
956 {
957    if (sd->profile.available_list)
958      {
959         Eina_Bool found = EINA_FALSE;
960         if (sd->profile.name)
961           {
962              unsigned int i;
963              for (i = 0; i < sd->profile.count; i++)
964                {
965                   if (!strcmp(sd->profile.name,
966                               sd->profile.available_list[i]))
967                     {
968                        found = EINA_TRUE;
969                        break;
970                     }
971                }
972           }
973
974         /* If current profile is not present in an available profiles,
975          * change current profile to the 1st element of an array.
976          */
977         if (!found)
978           _elm_win_profile_set(sd, sd->profile.available_list[0]);
979      }
980
981    _elm_config_profile_set(sd->profile.name);
982
983    /* update sub ee */
984    Ecore_Evas *ee2;
985    Eina_List *sub, *l = NULL;
986
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);
990
991    evas_object_smart_callback_call(sd->obj, SIG_PROFILE_CHANGED, NULL);
992 }
993
994 static void
995 _elm_win_state_change(Ecore_Evas *ee)
996 {
997    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
998    Evas_Object *obj;
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;
1007
1008    EINA_SAFETY_ON_NULL_RETURN(sd);
1009
1010    obj = sd->obj;
1011
1012    if (sd->withdrawn != ecore_evas_withdrawn_get(sd->ee))
1013      {
1014         sd->withdrawn = ecore_evas_withdrawn_get(sd->ee);
1015         ch_withdrawn = EINA_TRUE;
1016      }
1017    if (sd->sticky != ecore_evas_sticky_get(sd->ee))
1018      {
1019         sd->sticky = ecore_evas_sticky_get(sd->ee);
1020         ch_sticky = EINA_TRUE;
1021      }
1022    if (sd->iconified != ecore_evas_iconified_get(sd->ee))
1023      {
1024         sd->iconified = ecore_evas_iconified_get(sd->ee);
1025         ch_iconified = EINA_TRUE;
1026      }
1027    if (sd->fullscreen != ecore_evas_fullscreen_get(sd->ee))
1028      {
1029         sd->fullscreen = ecore_evas_fullscreen_get(sd->ee);
1030         ch_fullscreen = EINA_TRUE;
1031      }
1032    if (sd->maximized != ecore_evas_maximized_get(sd->ee))
1033      {
1034         sd->maximized = ecore_evas_maximized_get(sd->ee);
1035         ch_maximized = EINA_TRUE;
1036      }
1037
1038    profile = ecore_evas_window_profile_get(sd->ee);
1039    ch_profile = _elm_win_profile_set(sd, profile);
1040
1041    if (sd->wm_rot.use)
1042      {
1043         if (sd->rot != ecore_evas_rotation_get(sd->ee))
1044           {
1045              sd->rot = ecore_evas_rotation_get(sd->ee);
1046              ch_wm_rotation = EINA_TRUE;
1047           }
1048      }
1049
1050    _elm_win_state_eval_queue();
1051
1052    if ((ch_withdrawn) || (ch_iconified))
1053      {
1054         if (sd->withdrawn)
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);
1058         else
1059           evas_object_smart_callback_call(obj, SIG_NORMAL, NULL);
1060      }
1061    if (ch_sticky)
1062      {
1063         if (sd->sticky)
1064           evas_object_smart_callback_call(obj, SIG_STICK, NULL);
1065         else
1066           evas_object_smart_callback_call(obj, SIG_UNSTICK, NULL);
1067      }
1068    if (ch_fullscreen)
1069      {
1070         if (sd->fullscreen)
1071           evas_object_smart_callback_call(obj, SIG_FULLSCREEN, NULL);
1072         else
1073           evas_object_smart_callback_call(obj, SIG_UNFULLSCREEN, NULL);
1074      }
1075    if (ch_maximized)
1076      {
1077         if (sd->maximized)
1078           evas_object_smart_callback_call(obj, SIG_MAXIMIZED, NULL);
1079         else
1080           evas_object_smart_callback_call(obj, SIG_UNMAXIMIZED, NULL);
1081      }
1082    if (ch_profile)
1083      {
1084         _elm_win_profile_update(sd);
1085      }
1086    if (ch_wm_rotation)
1087      {
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);
1092 #endif
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);
1096      }
1097 }
1098
1099 static void
1100 _elm_win_smart_focus_next_manager_is(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list)
1101 {
1102    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1103    *ret = EINA_TRUE;
1104 }
1105
1106 static void
1107 _elm_win_smart_focus_next(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1108 {
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;
1113
1114    ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
1115
1116    const Eina_List *items;
1117    void *(*list_data_get)(const Eina_List *list);
1118
1119    /* Focus chain */
1120    if (wd->subobjs)
1121      {
1122         if (!(items = elm_widget_focus_custom_chain_get(obj)))
1123           {
1124              items = wd->subobjs;
1125              if (!items)
1126                return;
1127           }
1128         list_data_get = eina_list_data_get;
1129
1130         elm_widget_focus_list_next_get(obj, items, list_data_get, dir, next);
1131
1132         if (*next)
1133           {
1134              if (ret) *ret = EINA_TRUE;
1135              return;
1136           }
1137      }
1138    *next = (Evas_Object *)obj;
1139    return;
1140 }
1141
1142 static void
1143 _elm_win_smart_focus_direction_manager_is(Eo *obj EINA_UNUSED, void *_pd EINA_UNUSED, va_list *list)
1144 {
1145    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
1146    *ret = EINA_TRUE;
1147 }
1148
1149 static void
1150 _elm_win_smart_focus_direction(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1151 {
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;
1159
1160    const Eina_List *items;
1161    void *(*list_data_get)(const Eina_List *list);
1162
1163    ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd);
1164
1165    /* Focus chain */
1166    if (wd->subobjs)
1167      {
1168         if (!(items = elm_widget_focus_custom_chain_get(obj)))
1169           items = wd->subobjs;
1170
1171         list_data_get = eina_list_data_get;
1172
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;
1176      }
1177 }
1178
1179 static void
1180 _elm_win_smart_on_focus(Eo *obj, void *_pd, va_list *list)
1181 {
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;
1186
1187    eo_do_super(obj, MY_CLASS, elm_wdg_on_focus(&int_ret));
1188    if (!int_ret) return;
1189
1190    if (sd->img_obj)
1191      evas_object_focus_set(sd->img_obj, elm_widget_focus_get(obj));
1192    else
1193      evas_object_focus_set(obj, elm_widget_focus_get(obj));
1194 }
1195
1196 static void
1197 _elm_win_smart_event(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1198 {
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 *);
1203
1204    if (ret) *ret = EINA_FALSE;
1205    (void) src;
1206
1207    if (elm_widget_disabled_get(obj)) return;
1208    if (type != EVAS_CALLBACK_KEY_DOWN) return;
1209
1210    if ((!strcmp(ev->key, "Tab")) ||
1211        (!strcmp(ev->key, "ISO_Left_Tab")))
1212      {
1213         if (evas_key_modifier_is_set(ev->modifiers, "Control") ||
1214             evas_key_modifier_is_set(ev->modifiers, "Alt"))
1215           return;
1216         if (evas_key_modifier_is_set(ev->modifiers, "Shift"))
1217           elm_widget_focus_cycle(obj, ELM_FOCUS_PREVIOUS);
1218         else
1219           elm_widget_focus_cycle(obj, ELM_FOCUS_NEXT);
1220
1221         goto success;
1222      }
1223    else if ((!strcmp(ev->key, "Left")) ||
1224             ((!strcmp(ev->key, "KP_Left")) && (!ev->string)))
1225      {
1226         elm_widget_focus_cycle(obj, ELM_FOCUS_LEFT);
1227
1228         goto success;
1229      }
1230    else if ((!strcmp(ev->key, "Right")) ||
1231             ((!strcmp(ev->key, "KP_Right")) && (!ev->string)))
1232      {
1233         elm_widget_focus_cycle(obj, ELM_FOCUS_RIGHT);
1234
1235         goto success;
1236      }
1237    else if ((!strcmp(ev->key, "Up")) ||
1238             ((!strcmp(ev->key, "KP_Up")) && (!ev->string)))
1239      {
1240         elm_widget_focus_cycle(obj, ELM_FOCUS_UP);
1241
1242         goto success;
1243      }
1244    else if ((!strcmp(ev->key, "Down")) ||
1245             ((!strcmp(ev->key, "KP_Down")) && (!ev->string)))
1246      {
1247         elm_widget_focus_cycle(obj, ELM_FOCUS_DOWN);
1248
1249         goto success;
1250      }
1251
1252    return;
1253
1254 success:
1255    ev->event_flags |= EVAS_EVENT_FLAG_ON_HOLD;
1256    if (ret) *ret = EINA_TRUE;
1257 }
1258
1259 static void
1260 _deferred_ecore_evas_free(void *data)
1261 {
1262    ecore_evas_free(data);
1263    _elm_win_deferred_free--;
1264 }
1265
1266 static void
1267 _elm_win_smart_show(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
1268 {
1269    Elm_Win_Smart_Data *sd = _pd;
1270
1271    if (!evas_object_visible_get(obj))
1272      _elm_win_state_eval_queue();
1273    eo_do_super(obj, MY_CLASS, evas_obj_smart_show());
1274
1275    TRAP(sd, show);
1276
1277    if (sd->shot.info) _shot_handle(sd);
1278 }
1279
1280 static void
1281 _elm_win_smart_hide(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
1282 {
1283    Elm_Win_Smart_Data *sd = _pd;
1284
1285    if (evas_object_visible_get(obj))
1286      _elm_win_state_eval_queue();
1287    eo_do_super(obj, MY_CLASS, evas_obj_smart_hide());
1288
1289    TRAP(sd, hide);
1290
1291    if (sd->frame_obj)
1292      {
1293         evas_object_hide(sd->frame_obj);
1294      }
1295    if (sd->img_obj)
1296      {
1297         evas_object_hide(sd->img_obj);
1298      }
1299    if (sd->pointer.obj)
1300      {
1301         evas_object_hide(sd->pointer.obj);
1302         ecore_evas_hide(sd->pointer.ee);
1303      }
1304 }
1305
1306 static void
1307 _elm_win_on_parent_del(void *data,
1308                        Evas *e EINA_UNUSED,
1309                        Evas_Object *obj,
1310                        void *event_info EINA_UNUSED)
1311 {
1312    ELM_WIN_DATA_GET(data, sd);
1313
1314    if (obj == sd->parent) sd->parent = NULL;
1315 }
1316
1317 static void
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)
1322 {
1323    ELM_WIN_DATA_GET(data, sd);
1324
1325    sd->focus_highlight.geometry_changed = EINA_TRUE;
1326    _elm_win_focus_highlight_reconfigure_job_start(sd);
1327 }
1328
1329 static void
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)
1334 {
1335    ELM_WIN_DATA_GET(data, sd);
1336
1337    sd->focus_highlight.geometry_changed = EINA_TRUE;
1338    _elm_win_focus_highlight_reconfigure_job_start(sd);
1339 }
1340
1341 static void
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)
1346 {
1347    ELM_WIN_DATA_GET(data, sd);
1348
1349    sd->focus_highlight.cur.target = NULL;
1350
1351    _elm_win_focus_highlight_reconfigure_job_start(sd);
1352 }
1353
1354 static Evas_Object *
1355 _elm_win_focus_target_get(Evas_Object *obj)
1356 {
1357    Evas_Object *o = obj;
1358
1359    do
1360      {
1361         if (elm_widget_is(o))
1362           {
1363              if (!elm_widget_highlight_ignore_get(o))
1364                break;
1365              o = elm_widget_parent_get(o);
1366              if (!o)
1367                o = evas_object_smart_parent_get(o);
1368           }
1369         else
1370           {
1371              o = elm_widget_parent_widget_get(o);
1372              if (!o)
1373                o = evas_object_smart_parent_get(o);
1374           }
1375      }
1376    while (o);
1377
1378    return o;
1379 }
1380
1381 static void
1382 _elm_win_focus_target_callbacks_add(Elm_Win_Smart_Data *sd)
1383 {
1384    Evas_Object *obj = sd->focus_highlight.cur.target;
1385    if (!obj) return;
1386
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);
1393 }
1394
1395 static void
1396 _elm_win_focus_target_callbacks_del(Elm_Win_Smart_Data *sd)
1397 {
1398    Evas_Object *obj = sd->focus_highlight.cur.target;
1399
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);
1406 }
1407
1408 static void
1409 _elm_win_object_focus_in(void *data,
1410                          Evas *e EINA_UNUSED,
1411                          void *event_info)
1412 {
1413    Evas_Object *obj = event_info, *target;
1414    ELM_WIN_DATA_GET(data, sd);
1415
1416    if (sd->focus_highlight.cur.target == obj)
1417      return;
1418
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;
1423    else
1424      _elm_win_focus_target_callbacks_add(sd);
1425
1426    _elm_win_focus_highlight_reconfigure_job_start(sd);
1427 }
1428
1429 static void
1430 _elm_win_object_focus_out(void *data,
1431                           Evas *e EINA_UNUSED,
1432                           void *event_info EINA_UNUSED)
1433 {
1434    ELM_WIN_DATA_GET(data, sd);
1435
1436    if (!sd->focus_highlight.cur.target)
1437      return;
1438
1439    if (!sd->focus_highlight.cur.in_theme)
1440      _elm_win_focus_target_callbacks_del(sd);
1441
1442    sd->focus_highlight.cur.target = NULL;
1443    sd->focus_highlight.cur.in_theme = EINA_FALSE;
1444
1445    _elm_win_focus_highlight_reconfigure_job_start(sd);
1446 }
1447
1448 static void
1449 _elm_win_focus_highlight_shutdown(Elm_Win_Smart_Data *sd)
1450 {
1451    _elm_win_focus_highlight_reconfigure_job_stop(sd);
1452    if (sd->focus_highlight.cur.target)
1453      {
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;
1458      }
1459    ELM_SAFE_FREE(sd->focus_highlight.fobj, evas_object_del);
1460
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);
1467 }
1468
1469 static void
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)
1474 {
1475    ELM_WIN_DATA_GET(data, sd);
1476    sd->img_obj = NULL;
1477 }
1478
1479 static void
1480 _elm_win_smart_del(Eo *obj, void *_pd, va_list *list EINA_UNUSED)
1481 {
1482    Elm_Win_Smart_Data *sd = _pd;
1483
1484    evas_object_event_callback_del_full(sd->layout,
1485                                        EVAS_CALLBACK_CHANGED_SIZE_HINTS,
1486                                        _elm_win_on_resize_obj_changed_size_hints,
1487                                        obj);
1488    evas_object_del(sd->box);
1489    evas_object_del(sd->layout);
1490
1491    /* NB: child deletion handled by parent's smart del */
1492
1493    if ((trap) && (trap->del))
1494      trap->del(sd->trap_data, obj);
1495
1496    if (sd->parent)
1497      {
1498         evas_object_event_callback_del_full
1499           (sd->parent, EVAS_CALLBACK_DEL, _elm_win_on_parent_del, obj);
1500         sd->parent = NULL;
1501      }
1502
1503    if (sd->autodel_clear) *(sd->autodel_clear) = -1;
1504
1505    _elm_win_list = eina_list_remove(_elm_win_list, obj);
1506    _elm_win_count--;
1507    _elm_win_state_eval_queue();
1508
1509    if (sd->ee)
1510      {
1511         ecore_evas_callback_delete_request_set(sd->ee, NULL);
1512         ecore_evas_callback_resize_set(sd->ee, NULL);
1513      }
1514
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);
1519
1520 #ifdef HAVE_ELEMENTARY_X
1521    ecore_event_handler_del(sd->x.client_message_handler);
1522    ecore_event_handler_del(sd->x.property_handler);
1523 #endif
1524
1525    if (sd->img_obj)
1526      {
1527         evas_object_event_callback_del_full
1528            (sd->img_obj, EVAS_CALLBACK_DEL, _elm_win_on_img_obj_del, obj);
1529         sd->img_obj = NULL;
1530      }
1531    else
1532      {
1533         if (sd->ee)
1534           {
1535              ecore_job_add(_deferred_ecore_evas_free, sd->ee);
1536              _elm_win_deferred_free++;
1537           }
1538      }
1539
1540    _elm_win_focus_highlight_shutdown(sd);
1541    eina_stringshare_del(sd->focus_highlight.style);
1542
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);
1548
1549    _elm_win_profile_del(sd);
1550    _elm_win_available_profiles_del(sd);
1551
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);
1560
1561    eo_do_super(obj, MY_CLASS, evas_obj_smart_del());
1562
1563    if ((!_elm_win_list) &&
1564        (elm_policy_get(ELM_POLICY_QUIT) == ELM_POLICY_QUIT_LAST_WINDOW_CLOSED))
1565      {
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));
1570         elm_exit();
1571      }
1572 }
1573
1574 static void
1575 _elm_win_obj_intercept_show(void *data,
1576                             Evas_Object *obj)
1577 {
1578    ELM_WIN_DATA_GET(data, sd);
1579
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));
1584    if (sd->frame_obj)
1585      {
1586         evas_object_show(sd->frame_obj);
1587      }
1588    if (sd->img_obj)
1589      {
1590         evas_object_show(sd->img_obj);
1591      }
1592    if (sd->pointer.obj)
1593      {
1594         ecore_evas_show(sd->pointer.ee);
1595         evas_object_show(sd->pointer.obj);
1596      }
1597    evas_object_show(obj);
1598 }
1599
1600 static void
1601 _elm_win_smart_move(Eo *obj, void *_pd EINA_UNUSED, va_list *list)
1602 {
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;
1606
1607    if (sd->img_obj)
1608      {
1609         if ((x != sd->screen.x) || (y != sd->screen.y))
1610           {
1611              sd->screen.x = x;
1612              sd->screen.y = y;
1613              evas_object_smart_callback_call(obj, SIG_MOVED, NULL);
1614           }
1615         return;
1616      }
1617    else
1618      {
1619         TRAP(sd, move, x, y);
1620         if (!ecore_evas_override_get(sd->ee))  return;
1621      }
1622
1623    eo_do_super(obj, MY_CLASS, evas_obj_smart_move(x, y));
1624
1625    if (ecore_evas_override_get(sd->ee))
1626      {
1627         sd->screen.x = x;
1628         sd->screen.y = y;
1629         evas_object_smart_callback_call(obj, SIG_MOVED, NULL);
1630      }
1631    if (sd->frame_obj)
1632      {
1633         /* FIXME: We should update ecore_wl_window_location here !! */
1634         sd->screen.x = x;
1635         sd->screen.y = y;
1636      }
1637    if (sd->img_obj)
1638      {
1639         sd->screen.x = x;
1640         sd->screen.y = y;
1641      }
1642 }
1643
1644 static void
1645 _elm_win_smart_resize(Eo *obj, void *_pd, va_list *list)
1646 {
1647    Evas_Coord w = va_arg(*list, Evas_Coord);
1648    Evas_Coord h = va_arg(*list, Evas_Coord);
1649
1650    Elm_Win_Smart_Data *sd = _pd;
1651
1652    eo_do_super(obj, MY_CLASS, evas_obj_smart_resize(w, h));
1653
1654    if (sd->img_obj)
1655      {
1656         if (sd->constrain)
1657           {
1658              int sw, sh;
1659
1660              ecore_evas_screen_geometry_get(sd->ee, NULL, NULL, &sw, &sh);
1661              w = MIN(w, sw);
1662              h = MIN(h, sh);
1663           }
1664         if (w < 1) w = 1;
1665         if (h < 1) h = 1;
1666
1667         evas_object_image_size_set(sd->img_obj, w, h);
1668      }
1669
1670    TRAP(sd, resize, w, h);
1671 }
1672
1673 static void
1674 _elm_win_delete_request(Ecore_Evas *ee)
1675 {
1676    Elm_Win_Smart_Data *sd = _elm_win_associate_get(ee);
1677    Evas_Object *obj;
1678
1679    EINA_SAFETY_ON_NULL_RETURN(sd);
1680
1681    obj = sd->obj;
1682
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);
1691 }
1692
1693 Ecore_X_Window
1694 _elm_ee_xwin_get(const Ecore_Evas *ee)
1695 {
1696 #ifdef HAVE_ELEMENTARY_X
1697    const char *engine_name;
1698    if (!ee) return 0;
1699
1700    engine_name = ecore_evas_engine_name_get(ee);
1701    if (EINA_UNLIKELY(!engine_name)) return 0;
1702
1703    if (!strcmp(engine_name, ELM_SOFTWARE_X11))
1704      {
1705         return ecore_evas_software_x11_window_get(ee);
1706      }
1707    else if (!strcmp(engine_name, ELM_OPENGL_X11))
1708      {
1709         return ecore_evas_gl_x11_window_get(ee);
1710      }
1711    else if (!strcmp(engine_name, ELM_SOFTWARE_WIN32))
1712      {
1713         return (long)ecore_evas_win32_window_get(ee);
1714      }
1715 #endif
1716    return 0;
1717 }
1718
1719 #ifdef HAVE_ELEMENTARY_X
1720 static void
1721 _elm_win_xwindow_get(Elm_Win_Smart_Data *sd)
1722 {
1723    sd->x.xwin = _elm_ee_xwin_get(sd->ee);
1724 }
1725 #endif
1726
1727 Ecore_Wl_Window *
1728 _elm_ee_wlwin_get(const Ecore_Evas *ee)
1729 {
1730 #ifdef HAVE_ELEMENTARY_WAYLAND
1731    const char *engine_name;
1732
1733    if (!ee) return NULL;
1734
1735    engine_name = ecore_evas_engine_name_get(ee);
1736    if (EINA_UNLIKELY(!engine_name)) return NULL;
1737
1738    if ((!strcmp(engine_name, ELM_WAYLAND_SHM)) ||
1739        (!strcmp(engine_name, ELM_WAYLAND_EGL)))
1740      {
1741         return ecore_evas_wayland_window_get(ee);
1742      }
1743 #else
1744    (void)ee;
1745 #endif
1746    return NULL;
1747 }
1748
1749 #ifdef HAVE_ELEMENTARY_WAYLAND
1750 static void
1751 _elm_win_wlwindow_get(Elm_Win_Smart_Data *sd)
1752 {
1753    sd->wl.win = _elm_ee_wlwin_get(sd->ee);
1754 }
1755 #endif
1756
1757 #ifdef HAVE_ELEMENTARY_X
1758 static void
1759 _elm_win_xwin_update(Elm_Win_Smart_Data *sd)
1760 {
1761    const char *s;
1762
1763    _elm_win_xwindow_get(sd);
1764    if (sd->parent)
1765      {
1766         ELM_WIN_DATA_GET(sd->parent, sdp);
1767         if (sdp)
1768           {
1769              if (sd->x.xwin)
1770                ecore_x_icccm_transient_for_set(sd->x.xwin, sdp->x.xwin);
1771           }
1772      }
1773
1774    if (!sd->x.xwin) return;  /* nothing more to do */
1775
1776    s = sd->title;
1777    if (!s) s = _elm_appname;
1778    if (!s) s = "";
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);
1782
1783    s = sd->role;
1784    if (s) ecore_x_icccm_window_role_set(sd->x.xwin, s);
1785
1786    // set window icon
1787    if (sd->icon)
1788      {
1789         void *data;
1790
1791         data = evas_object_image_data_get(sd->icon, EINA_FALSE);
1792         if (data)
1793           {
1794              Ecore_X_Icon ic;
1795              int w = 0, h = 0, stride, x, y;
1796              unsigned char *p;
1797              unsigned int *p2;
1798
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))))
1803                {
1804                   ic.width = w;
1805                   ic.height = h;
1806                   ic.data = malloc(w * h * sizeof(unsigned int));
1807
1808                   if (ic.data)
1809                     {
1810                        p = (unsigned char *)data;
1811                        p2 = (unsigned int *)ic.data;
1812                        for (y = 0; y < h; y++)
1813                          {
1814                             for (x = 0; x < w; x++)
1815                               {
1816                                  *p2 = *((unsigned int *)p);
1817                                  p += sizeof(unsigned int);
1818                                  p2++;
1819                               }
1820                             p += (stride - (w * sizeof(unsigned int)));
1821                          }
1822                        ecore_x_netwm_icons_set(sd->x.xwin, &ic, 1);
1823                        free(ic.data);
1824                     }
1825                }
1826              evas_object_image_data_set(sd->icon, data);
1827           }
1828      }
1829
1830    switch (sd->type)
1831      {
1832       case ELM_WIN_BASIC:
1833         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_NORMAL);
1834         break;
1835
1836       case ELM_WIN_DIALOG_BASIC:
1837         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DIALOG);
1838         break;
1839
1840       case ELM_WIN_DESKTOP:
1841         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DESKTOP);
1842         break;
1843
1844       case ELM_WIN_DOCK:
1845         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DOCK);
1846         break;
1847
1848       case ELM_WIN_TOOLBAR:
1849         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_TOOLBAR);
1850         break;
1851
1852       case ELM_WIN_MENU:
1853         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_MENU);
1854         break;
1855
1856       case ELM_WIN_UTILITY:
1857         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_UTILITY);
1858         break;
1859
1860       case ELM_WIN_SPLASH:
1861         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_SPLASH);
1862         break;
1863
1864       case ELM_WIN_DROPDOWN_MENU:
1865         ecore_x_netwm_window_type_set
1866           (sd->x.xwin, ECORE_X_WINDOW_TYPE_DROPDOWN_MENU);
1867         break;
1868
1869       case ELM_WIN_POPUP_MENU:
1870         ecore_x_netwm_window_type_set
1871           (sd->x.xwin, ECORE_X_WINDOW_TYPE_POPUP_MENU);
1872         break;
1873
1874       case ELM_WIN_TOOLTIP:
1875         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_TOOLTIP);
1876         break;
1877
1878       case ELM_WIN_NOTIFICATION:
1879         ecore_x_netwm_window_type_set
1880           (sd->x.xwin, ECORE_X_WINDOW_TYPE_NOTIFICATION);
1881         break;
1882
1883       case ELM_WIN_COMBO:
1884         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_COMBO);
1885         break;
1886
1887       case ELM_WIN_DND:
1888         ecore_x_netwm_window_type_set(sd->x.xwin, ECORE_X_WINDOW_TYPE_DND);
1889         break;
1890
1891       default:
1892         break;
1893      }
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);
1902 }
1903
1904 #endif
1905
1906 /**
1907   * @internal
1908   *
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
1911   * min size.
1912   *
1913   * This is called when the window layout's weight hint is changed or when the
1914   * window is rotated.
1915   *
1916   * @param obj window object
1917   */
1918 static void
1919 _elm_win_resize_objects_eval(Evas_Object *obj)
1920 {
1921    ELM_WIN_DATA_GET(obj, sd);
1922    Evas_Coord w, h, minw, minh, maxw, maxh;
1923    double wx, wy;
1924
1925    evas_object_size_hint_min_get(sd->layout, &minw, &minh);
1926    if (minw < 1) minw = 1;
1927    if (minh < 1) minh = 1;
1928
1929    evas_object_size_hint_weight_get(sd->layout, &wx, &wy);
1930    if (!wx) maxw = minw;
1931    else maxw = 32767;
1932    if (!wy) maxh = minh;
1933    else maxh = 32767;
1934
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);
1944 }
1945
1946 static void
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)
1951 {
1952    _elm_win_resize_objects_eval(data);
1953 }
1954
1955 void
1956 _elm_win_shutdown(void)
1957 {
1958    while (_elm_win_list) evas_object_del(_elm_win_list->data);
1959    ELM_SAFE_FREE(_elm_win_state_eval_job, ecore_job_del);
1960 }
1961
1962 void
1963 _elm_win_rescale(Elm_Theme *th,
1964                  Eina_Bool use_theme)
1965 {
1966    const Eina_List *l;
1967    Evas_Object *obj;
1968
1969    if (!use_theme)
1970      {
1971         EINA_LIST_FOREACH(_elm_win_list, l, obj)
1972           elm_widget_theme(obj);
1973      }
1974    else
1975      {
1976         EINA_LIST_FOREACH(_elm_win_list, l, obj)
1977           elm_widget_theme_specific(obj, th, EINA_FALSE);
1978      }
1979 }
1980
1981 void
1982 _elm_win_access(Eina_Bool is_access)
1983 {
1984    Evas *evas;
1985    const Eina_List *l;
1986    Evas_Object *obj;
1987    Evas_Object *fobj;
1988
1989    EINA_LIST_FOREACH(_elm_win_list, l, obj)
1990      {
1991         elm_widget_access(obj, is_access);
1992
1993          /* floating orphan object. if there are A, B, C objects and user does
1994             as below, then there would be floating orphan objects.
1995
1996               1. elm_object_content_set(layout, A);
1997               2. elm_object_content_set(layout, B);
1998               3. elm_object_content_set(layout, C);
1999
2000             now, the object A and B are floating orphan objects */
2001
2002         fobj = obj;
2003         for (;;)
2004           {
2005              fobj = evas_object_below_get(fobj);
2006              if (!fobj) break;
2007
2008              if (elm_widget_is(fobj) && !elm_widget_parent_get(fobj))
2009                {
2010                   elm_widget_access(fobj, is_access);
2011                }
2012           }
2013
2014         if (!is_access)
2015           {
2016              evas = evas_object_evas_get(obj);
2017             if (evas) _elm_access_object_highlight_disable(evas);
2018           }
2019      }
2020 }
2021
2022 void
2023 _elm_win_translate(void)
2024 {
2025    const Eina_List *l;
2026    Evas_Object *obj;
2027
2028    EINA_LIST_FOREACH(_elm_win_list, l, obj)
2029      elm_widget_translate(obj);
2030 }
2031
2032 #ifdef HAVE_ELEMENTARY_X
2033 static Eina_Bool
2034 _elm_win_client_message(void *data,
2035                         int type EINA_UNUSED,
2036                         void *event)
2037 {
2038    ELM_WIN_DATA_GET(data, sd);
2039    Ecore_X_Event_Client_Message *e = event;
2040
2041    if (e->format != 32) return ECORE_CALLBACK_PASS_ON;
2042    if (e->message_type == ECORE_X_ATOM_E_COMP_FLUSH)
2043      {
2044         if ((unsigned int)e->data.l[0] == sd->x.xwin)
2045           {
2046              Evas *evas = evas_object_evas_get(sd->obj);
2047              if (evas)
2048                {
2049                   edje_file_cache_flush();
2050                   edje_collection_cache_flush();
2051                   evas_image_cache_flush(evas);
2052                   evas_font_cache_flush(evas);
2053                }
2054           }
2055      }
2056    else if (e->message_type == ECORE_X_ATOM_E_COMP_DUMP)
2057      {
2058         if ((unsigned int)e->data.l[0] == sd->x.xwin)
2059           {
2060              Evas *evas = evas_object_evas_get(sd->obj);
2061              if (evas)
2062                {
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);
2068                }
2069           }
2070      }
2071    else if (e->message_type == ECORE_X_ATOM_E_ILLUME_ACCESS_CONTROL)
2072      {
2073         if ((unsigned int)e->data.l[0] == sd->x.xwin)
2074           {
2075              if ((unsigned int)e->data.l[1] ==
2076                  ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_NEXT)
2077                {
2078                   // XXX: call right access func
2079                }
2080              else if ((unsigned int)e->data.l[1] ==
2081                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_PREV)
2082                {
2083                   // XXX: call right access func
2084                }
2085              else if ((unsigned int)e->data.l[1] ==
2086                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_ACTIVATE)
2087                {
2088                   _elm_access_highlight_object_activate
2089                     (sd->obj, ELM_ACTIVATE_DEFAULT);
2090                }
2091              else if ((unsigned int)e->data.l[1] ==
2092                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_READ)
2093                {
2094                   /* there would be better way to read highlight object */
2095                   Evas *evas;
2096                   evas = evas_object_evas_get(sd->obj);
2097                   if (!evas) return ECORE_CALLBACK_PASS_ON;
2098
2099                   _elm_access_mouse_event_enabled_set(EINA_TRUE);
2100
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);
2104
2105                   _elm_access_mouse_event_enabled_set(EINA_FALSE);
2106                }
2107              else if ((unsigned int)e->data.l[1] ==
2108                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_READ_NEXT)
2109                {
2110                   _elm_access_highlight_cycle(sd->obj, ELM_FOCUS_NEXT);
2111                }
2112              else if ((unsigned int)e->data.l[1] ==
2113                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_READ_PREV)
2114                {
2115                   _elm_access_highlight_cycle(sd->obj, ELM_FOCUS_PREVIOUS);
2116                }
2117              else if ((unsigned int)e->data.l[1] ==
2118                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_UP)
2119                {
2120                   _elm_access_highlight_object_activate
2121                     (sd->obj, ELM_ACTIVATE_UP);
2122                }
2123              else if ((unsigned int)e->data.l[1] ==
2124                       ECORE_X_ATOM_E_ILLUME_ACCESS_ACTION_DOWN)
2125                {
2126                   _elm_access_highlight_object_activate
2127                     (sd->obj, ELM_ACTIVATE_DOWN);
2128                }
2129           }
2130      }
2131    return ECORE_CALLBACK_PASS_ON;
2132 }
2133
2134 static Eina_Bool
2135 _elm_win_property_change(void *data,
2136                          int type EINA_UNUSED,
2137                          void *event)
2138 {
2139    ELM_WIN_DATA_GET(data, sd);
2140    Ecore_X_Event_Window_Property *e = event;
2141
2142    if (e->atom == ECORE_X_ATOM_E_ILLUME_INDICATOR_STATE)
2143      {
2144         if (e->win == sd->x.xwin)
2145           {
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);
2148           }
2149      }
2150    return ECORE_CALLBACK_PASS_ON;
2151 }
2152 #endif
2153
2154 static void
2155 _elm_win_focus_highlight_hide(void *data EINA_UNUSED,
2156                               Evas_Object *obj,
2157                               const char *emission EINA_UNUSED,
2158                               const char *source EINA_UNUSED)
2159 {
2160    evas_object_hide(obj);
2161 }
2162
2163 static void
2164 _elm_win_focus_highlight_anim_end(void *data,
2165                                   Evas_Object *obj,
2166                                   const char *emission EINA_UNUSED,
2167                                   const char *source EINA_UNUSED)
2168 {
2169    ELM_WIN_DATA_GET(data, sd);
2170
2171    _elm_win_focus_highlight_simple_setup(sd, obj);
2172 }
2173
2174 static void
2175 _elm_win_focus_highlight_init(Elm_Win_Smart_Data *sd)
2176 {
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);
2182
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;
2186
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);
2194 }
2195
2196 static void
2197 _elm_win_frame_cb_move_start(void *data,
2198                              Evas_Object *obj EINA_UNUSED,
2199                              const char *sig EINA_UNUSED,
2200                              const char *source)
2201 {
2202    ELM_WIN_DATA_GET(data, sd);
2203
2204    if (!sd) return;
2205
2206 #ifdef HAVE_ELEMENTARY_WAYLAND
2207    if (!strcmp(source, "elm"))
2208      ecore_wl_window_cursor_from_name_set(sd->wl.win, ELM_CURSOR_HAND1);
2209    else
2210      ecore_wl_window_cursor_default_restore(sd->wl.win);
2211 #else
2212    (void)source;
2213 #endif
2214
2215    /* FIXME: Change mouse pointer */
2216
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 */
2222
2223    ecore_evas_wayland_move(sd->ee, sd->screen.x, sd->screen.y);
2224 }
2225
2226 static void
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)
2231 {
2232    ELM_WIN_DATA_GET(data, sd);
2233
2234    if (!sd) return;
2235
2236 #ifdef HAVE_ELEMENTARY_WAYLAND
2237    ecore_wl_window_cursor_default_restore(sd->wl.win);
2238 #endif
2239 }
2240
2241 #ifdef HAVE_ELEMENTARY_WAYLAND
2242 struct _resize_info
2243 {
2244    const char *name;
2245    int location;
2246 };
2247
2248 static struct _resize_info _border_side[4] =
2249 {
2250      { ELM_CURSOR_TOP_SIDE, 1 },
2251      { ELM_CURSOR_LEFT_SIDE, 4 },
2252      { ELM_CURSOR_BOTTOM_SIDE, 2 },
2253      { ELM_CURSOR_RIGHT_SIDE, 8 },
2254 };
2255
2256 static struct _resize_info _border_corner[4] =
2257 {
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 },
2262 };
2263 #endif
2264
2265 static void
2266 _elm_win_frame_obj_update(Elm_Win_Smart_Data *sd)
2267 {
2268    int fx, fy, fw, fh;
2269    int ox, oy, ow, oh;
2270    int sx, sy, sw, sh;
2271    int x, y, w, h;
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);
2275
2276    evas_output_framespace_get(sd->evas, &x, &y, &w, &h);
2277
2278    if ((x != (ox - fx)) || (y != (oy - fy)) ||
2279        (w != (fw - ow)) || (h != (fh - oh)))
2280      {
2281         evas_output_framespace_set(sd->evas, (ox - fx), (oy - fy),
2282                                    (fw - ow), (fh - oh));
2283      }
2284
2285 #ifdef HAVE_ELEMENTARY_WAYLAND
2286    ecore_wl_window_opaque_region_set(sd->wl.win, -fx, -(fy - sy), sw, sh);
2287 #endif
2288 }
2289
2290 static void
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)
2295 {
2296    Elm_Win_Smart_Data *sd;
2297
2298    if (!(sd = data)) return;
2299    if (!sd->client_obj) return;
2300
2301    _elm_win_frame_obj_update(sd);
2302 }
2303
2304 static void
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)
2309 {
2310    Elm_Win_Smart_Data *sd;
2311
2312    if (!(sd = data)) return;
2313    if (!sd->client_obj) return;
2314
2315    _elm_win_frame_obj_update(sd);
2316 }
2317
2318 static void
2319 _elm_win_frame_cb_resize_show(void *data,
2320                               Evas_Object *obj EINA_UNUSED,
2321                               const char *sig EINA_UNUSED,
2322                               const char *source)
2323 {
2324    ELM_WIN_DATA_GET(data, sd);
2325
2326    if (!sd) return;
2327    if (sd->resizing) return;
2328
2329 #ifdef HAVE_ELEMENTARY_WAYLAND
2330    int i;
2331    i = sd->rot / 90;
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);
2356    else
2357      ecore_wl_window_cursor_default_restore(sd->wl.win);
2358 #else
2359    (void)source;
2360 #endif
2361 }
2362
2363 static void
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)
2368 {
2369    ELM_WIN_DATA_GET(data, sd);
2370
2371    if (!sd) return;
2372    if (sd->resizing) return;
2373
2374 #ifdef HAVE_ELEMENTARY_WAYLAND
2375    ecore_wl_window_cursor_default_restore(sd->wl.win);
2376 #endif
2377 }
2378
2379 static void
2380 _elm_win_frame_cb_resize_start(void *data,
2381                                Evas_Object *obj EINA_UNUSED,
2382                                const char *sig EINA_UNUSED,
2383                                const char *source)
2384 {
2385 #ifdef HAVE_ELEMENTARY_WAYLAND
2386    ELM_WIN_DATA_GET(data, sd);
2387    int i;
2388
2389    if (!sd) return;
2390    if (sd->resizing) return;
2391
2392    sd->resizing = EINA_TRUE;
2393    i = sd->rot / 90;
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;
2410    else
2411      sd->resize_location = 0;
2412
2413    if (sd->resize_location > 0)
2414      ecore_evas_wayland_resize(sd->ee, sd->resize_location);
2415 #else
2416    (void)data;
2417    (void)source;
2418 #endif
2419 }
2420
2421 static void
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)
2426 {
2427    ELM_WIN_DATA_GET(data, sd);
2428
2429    if (!sd) return;
2430 //   sd->iconified = EINA_TRUE;
2431    TRAP(sd, iconified_set, EINA_TRUE);
2432 }
2433
2434 static void
2435 _elm_win_frame_maximized_state_update(Elm_Win_Smart_Data *sd, Eina_Bool maximized)
2436 {
2437    const char *emission;
2438
2439    if (maximized)
2440      emission = "elm,state,maximized";
2441    else
2442      emission = "elm,state,unmaximized";
2443
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);
2447
2448    _elm_win_frame_obj_update(sd);
2449 }
2450
2451 static void
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)
2456 {
2457    Eina_Bool value;
2458    ELM_WIN_DATA_GET(data, sd);
2459
2460    if (!sd) return;
2461    if (sd->maximized) value = EINA_FALSE;
2462    else value = EINA_TRUE;
2463
2464    _elm_win_frame_maximized_state_update(sd, value);
2465
2466    TRAP(sd, maximized_set, value);
2467 }
2468
2469 static void
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)
2474 {
2475    ELM_WIN_DATA_GET(data, sd);
2476    Evas_Object *win;
2477
2478    /* FIXME: After the current freeze, this should be handled differently.
2479     *
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.
2485     *
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
2489     */
2490
2491    if (!sd) return;
2492
2493    win = sd->obj;
2494
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);
2503 }
2504
2505 static void
2506 _elm_win_frame_add(Elm_Win_Smart_Data *sd,
2507                    const char *style)
2508 {
2509    Evas_Object *obj = sd->obj;
2510    int w, h, mw, mh;
2511    short layer;
2512
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))
2518      {
2519         ELM_SAFE_FREE(sd->frame_obj, evas_object_del);
2520         return;
2521      }
2522
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",
2527                             sd->spacer_obj);
2528
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",
2534                             sd->client_obj);
2535
2536    evas_object_is_frame_object_set(sd->frame_obj, EINA_TRUE);
2537
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);
2542
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);
2549
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);
2573
2574    if (sd->title)
2575      {
2576         edje_object_part_text_escaped_set
2577           (sd->frame_obj, "elm.text.title", sd->title);
2578      }
2579
2580    ecore_evas_geometry_get(sd->ee, NULL, NULL, &w, &h);
2581    ecore_evas_resize(sd->ee, w, h);
2582 }
2583
2584 static void
2585 _elm_win_frame_del(Elm_Win_Smart_Data *sd)
2586 {
2587    int w, h;
2588
2589    ELM_SAFE_FREE(sd->client_obj, evas_object_del);
2590
2591    if (sd->frame_obj)
2592      {
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);
2597
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);
2622
2623         ELM_SAFE_FREE(sd->frame_obj, evas_object_del);
2624      }
2625
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);
2629 }
2630
2631 #ifdef ELM_DEBUG
2632 static void
2633 _debug_key_down(void *data EINA_UNUSED,
2634                 Evas *e EINA_UNUSED,
2635                 Evas_Object *obj,
2636                 void *event_info)
2637 {
2638    Evas_Event_Key_Down *ev = event_info;
2639
2640    if (ev->event_flags & EVAS_EVENT_FLAG_ON_HOLD)
2641      return;
2642
2643    if ((strcmp(ev->key, "F12")) ||
2644        (!evas_key_modifier_is_set(ev->modifiers, "Control")))
2645      return;
2646
2647    INF("Tree graph generated.");
2648    elm_object_tree_dot_dump(obj, "./dump.dot");
2649 }
2650
2651 #endif
2652
2653 static void
2654 _win_img_hide(void *data,
2655               Evas *e EINA_UNUSED,
2656               Evas_Object *obj EINA_UNUSED,
2657               void *event_info EINA_UNUSED)
2658 {
2659    elm_widget_focus_hide_handle(data);
2660 }
2661
2662 static void
2663 _win_img_mouse_up(void *data,
2664                   Evas *e EINA_UNUSED,
2665                   Evas_Object *obj EINA_UNUSED,
2666                   void *event_info)
2667 {
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);
2671 }
2672
2673 static void
2674 _win_img_focus_in(void *data,
2675                   Evas *e EINA_UNUSED,
2676                   Evas_Object *obj EINA_UNUSED,
2677                   void *event_info EINA_UNUSED)
2678 {
2679    elm_widget_focus_steal(data);
2680 }
2681
2682 static void
2683 _win_img_focus_out(void *data,
2684                    Evas *e EINA_UNUSED,
2685                    Evas_Object *obj EINA_UNUSED,
2686                    void *event_info EINA_UNUSED)
2687 {
2688    elm_widget_focused_object_clear(data);
2689 }
2690
2691 static void
2692 _win_inlined_image_set(Elm_Win_Smart_Data *sd)
2693 {
2694    evas_object_image_alpha_set(sd->img_obj, EINA_FALSE);
2695    evas_object_image_filled_set(sd->img_obj, EINA_TRUE);
2696
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);
2707 }
2708
2709 static void
2710 _elm_win_on_icon_del(void *data,
2711                      Evas *e EINA_UNUSED,
2712                      Evas_Object *obj,
2713                      void *event_info EINA_UNUSED)
2714 {
2715    ELM_WIN_DATA_GET(data, sd);
2716
2717    if (sd->icon == obj) sd->icon = NULL;
2718 }
2719
2720 static void
2721 _elm_win_smart_add(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED)
2722 {
2723    eo_do_super(obj, MY_CLASS, evas_obj_smart_add());
2724
2725    elm_widget_can_focus_set(obj, EINA_TRUE);
2726
2727    elm_widget_highlight_ignore_set(obj, EINA_TRUE);
2728 }
2729
2730 #ifdef HAVE_ELEMENTARY_X
2731 static void
2732 _elm_x_io_err(void *data EINA_UNUSED)
2733 {
2734    Eina_List *l;
2735    Evas_Object *obj;
2736
2737    EINA_LIST_FOREACH(_elm_win_list, l, obj)
2738      evas_object_smart_callback_call(obj, SIG_IOERR, NULL);
2739    elm_exit();
2740 }
2741 #endif
2742
2743 EAPI Evas_Object *
2744 elm_win_add(Evas_Object *parent,
2745             const char *name,
2746             Elm_Win_Type type)
2747 {
2748    Evas_Object *obj = eo_add_custom(MY_CLASS, parent, elm_obj_win_constructor(name, type));
2749    eo_unref(obj);
2750    return obj;
2751 }
2752
2753 static void
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)
2758 {
2759    _elm_win_state_eval_queue();
2760 }
2761
2762 static void
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)
2767 {
2768    _elm_win_state_eval_queue();
2769 }
2770
2771 /**
2772   * @internal
2773   *
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.
2777   *
2778   * @param o box object
2779   * @param p box's private data
2780   * @param data window object
2781   */
2782 static void
2783 _window_layout_stack(Evas_Object *o, Evas_Object_Box_Data *p, void *data)
2784 {
2785    const Eina_List *l;
2786    Evas_Object *child;
2787    Evas_Object_Box_Option *opt;
2788    Evas_Coord x, y, w, h;
2789    double wx, wy;
2790    Evas_Coord minw = -1, minh = -1;
2791    double weight_x = EVAS_HINT_EXPAND;
2792    double weight_y = EVAS_HINT_EXPAND;
2793
2794    EINA_LIST_FOREACH(p->children, l, opt)
2795      {
2796         child = opt->obj;
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;
2800
2801         evas_object_size_hint_min_get(child, &w, &h);
2802         if (w > minw) minw = w;
2803         if (h > minh) minh = h;
2804      }
2805
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);
2811
2812    EINA_LIST_FOREACH(p->children, l, opt)
2813      {
2814         child = opt->obj;
2815         evas_object_move(child, x, y);
2816         evas_object_resize(child, w, h);
2817      }
2818
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);
2822 }
2823
2824 static void
2825 _win_constructor(Eo *obj, void *_pd, va_list *list)
2826 {
2827    Elm_Win_Smart_Data *sd = _pd;
2828    sd->obj = obj; // in ctor
2829
2830    const char *name = va_arg(*list, const char *);
2831    Elm_Win_Type type = va_arg(*list, Elm_Win_Type);
2832    Evas_Object *parent;
2833    Evas *e;
2834    const Eina_List *l;
2835    const char *fontpath, *fallback = NULL;
2836
2837    Elm_Win_Smart_Data tmp_sd;
2838
2839    eo_do(obj, eo_parent_get(&parent));
2840
2841    /* just to store some data while trying out to create a canvas */
2842    memset(&tmp_sd, 0, sizeof(Elm_Win_Smart_Data));
2843
2844 #define FALLBACK_TRY(engine)                                      \
2845   if (!tmp_sd.ee) {                                               \
2846      CRI(engine " engine creation failed. Trying default."); \
2847   } while (0)
2848 #define FALLBACK_STORE(engine)                               \
2849    if (tmp_sd.ee)                                            \
2850    {                                                         \
2851       CRI(engine "Fallback to %s successful.", engine); \
2852       fallback = engine;                                     \
2853    }
2854
2855    switch (type)
2856      {
2857       case ELM_WIN_INLINED_IMAGE:
2858         if (!parent) break;
2859           {
2860              e = evas_object_evas_get(parent);
2861              Ecore_Evas *ee;
2862
2863              if (!e) break;
2864
2865              ee = ecore_evas_ecore_evas_get(e);
2866              if (!ee) break;
2867
2868              tmp_sd.img_obj = ecore_evas_object_image_new(ee);
2869              if (!tmp_sd.img_obj) break;
2870
2871              tmp_sd.ee = ecore_evas_object_ecore_evas_get(tmp_sd.img_obj);
2872              if (!tmp_sd.ee)
2873                {
2874                   ELM_SAFE_FREE(tmp_sd.img_obj, evas_object_del);
2875                }
2876           }
2877         break;
2878
2879       case ELM_WIN_SOCKET_IMAGE:
2880         tmp_sd.ee = ecore_evas_extn_socket_new(1, 1);
2881         break;
2882
2883       default:
2884         if (ENGINE_COMPARE(ELM_SOFTWARE_X11))
2885           {
2886              tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2887              FALLBACK_TRY("Software X11");
2888              if (!tmp_sd.ee)
2889                {
2890                   tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2891                   FALLBACK_STORE("Software FB");
2892                }
2893           }
2894         else if (ENGINE_COMPARE(ELM_SOFTWARE_FB))
2895           {
2896              tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2897              FALLBACK_TRY("Software FB");
2898              if (!tmp_sd.ee)
2899                {
2900                   tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2901                   FALLBACK_STORE("Software X11");
2902                }
2903           }
2904         else if (ENGINE_COMPARE(ELM_OPENGL_X11))
2905           {
2906              int opt[10];
2907              int opt_i = 0;
2908
2909              if (_elm_config->vsync)
2910                {
2911                   opt[opt_i] = ECORE_EVAS_GL_X11_OPT_VSYNC;
2912                   opt_i++;
2913                   opt[opt_i] = 1;
2914                   opt_i++;
2915                   opt[opt_i] = 0;
2916                }
2917              if (opt_i > 0)
2918                tmp_sd.ee = ecore_evas_gl_x11_options_new
2919                    (NULL, 0, 0, 0, 1, 1, opt);
2920              else
2921                tmp_sd.ee = ecore_evas_gl_x11_new(NULL, 0, 0, 0, 1, 1);
2922              FALLBACK_TRY("OpenGL");
2923              if (!tmp_sd.ee)
2924                {
2925                   tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2926                   FALLBACK_STORE("Software X11");
2927                   if (!tmp_sd.ee)
2928                     {
2929                        tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2930                        FALLBACK_STORE("Software FB");
2931                     }
2932                }
2933           }
2934         else if (ENGINE_COMPARE(ELM_SOFTWARE_WIN32))
2935           {
2936              tmp_sd.ee = ecore_evas_software_gdi_new(NULL, 0, 0, 1, 1);
2937              FALLBACK_TRY("Software Win32");
2938           }
2939         else if (ENGINE_COMPARE(ELM_SOFTWARE_PSL1GHT))
2940           {
2941              tmp_sd.ee = ecore_evas_psl1ght_new(NULL, 1, 1);
2942              FALLBACK_TRY("PSL1GHT");
2943           }
2944         else if (ENGINE_COMPARE(ELM_SOFTWARE_SDL))
2945           {
2946              tmp_sd.ee = ecore_evas_sdl_new(NULL, 0, 0, 0, 0, 0, 1);
2947              FALLBACK_TRY("Software SDL");
2948              if (!tmp_sd.ee)
2949                {
2950                   tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2951                   FALLBACK_STORE("Software X11");
2952                   if (!tmp_sd.ee)
2953                     {
2954                        tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2955                        FALLBACK_STORE("Software FB");
2956                     }
2957                }
2958           }
2959         else if (ENGINE_COMPARE(ELM_SOFTWARE_16_SDL))
2960           {
2961              tmp_sd.ee = ecore_evas_sdl16_new(NULL, 0, 0, 0, 0, 0, 1);
2962              FALLBACK_TRY("Software-16-SDL");
2963              if (!tmp_sd.ee)
2964                {
2965                   tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2966                   FALLBACK_STORE("Software X11");
2967                   if (!tmp_sd.ee)
2968                     {
2969                        tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2970                        FALLBACK_STORE("Software FB");
2971                     }
2972                }
2973           }
2974         else if (ENGINE_COMPARE(ELM_OPENGL_SDL))
2975           {
2976              tmp_sd.ee = ecore_evas_gl_sdl_new(NULL, 1, 1, 0, 0);
2977              FALLBACK_TRY("OpenGL SDL");
2978              if (!tmp_sd.ee)
2979                {
2980                   tmp_sd.ee = ecore_evas_software_x11_new(NULL, 0, 0, 0, 1, 1);
2981                   FALLBACK_STORE("Software X11");
2982                   if (!tmp_sd.ee)
2983                     {
2984                        tmp_sd.ee = ecore_evas_fb_new(NULL, 0, 1, 1);
2985                        FALLBACK_STORE("Software FB");
2986                     }
2987                }
2988           }
2989         else if (ENGINE_COMPARE(ELM_OPENGL_COCOA))
2990           {
2991              tmp_sd.ee = ecore_evas_cocoa_new(NULL, 1, 1, 0, 0);
2992              FALLBACK_TRY("OpenGL Cocoa");
2993           }
2994         else if (ENGINE_COMPARE(ELM_BUFFER))
2995           {
2996              tmp_sd.ee = ecore_evas_buffer_new(1, 1);
2997           }
2998         else if (ENGINE_COMPARE(ELM_EWS))
2999           {
3000              tmp_sd.ee = ecore_evas_ews_new(0, 0, 1, 1);
3001           }
3002         else if (ENGINE_COMPARE(ELM_WAYLAND_SHM))
3003           {
3004              tmp_sd.ee = ecore_evas_wayland_shm_new(NULL, 0, 0, 0, 1, 1, 0);
3005           }
3006         else if (ENGINE_COMPARE(ELM_WAYLAND_EGL))
3007           {
3008              tmp_sd.ee = ecore_evas_wayland_egl_new(NULL, 0, 0, 0, 1, 1, 0);
3009           }
3010         else if (!strncmp(ENGINE_GET(), "shot:", 5))
3011           {
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
3015                  (ENGINE_GET() + 5);
3016           }
3017 #undef FALLBACK_TRY
3018         break;
3019      }
3020
3021    if (!tmp_sd.ee)
3022      {
3023         ERR("Cannot create window.");
3024         eo_error_set(obj);
3025         return;
3026      }
3027
3028    eo_do(obj, eo_parent_set(ecore_evas_get(tmp_sd.ee)));
3029    eo_do_super(obj, MY_CLASS, eo_constructor());
3030    eo_do(obj,
3031          evas_obj_type_set(MY_CLASS_NAME_LEGACY),
3032          evas_obj_smart_callbacks_descriptions_set(_smart_callbacks, NULL));
3033
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"));
3037
3038    /* copying possibly altered fields back */
3039 #define SD_CPY(_field)             \
3040   do                               \
3041     {                              \
3042        sd->_field = tmp_sd._field; \
3043     } while (0)
3044
3045    SD_CPY(ee);
3046    SD_CPY(img_obj);
3047    SD_CPY(shot.info);
3048 #undef SD_CPY
3049
3050    if ((trap) && (trap->add))
3051      sd->trap_data = trap->add(obj);
3052
3053    /* complementary actions, which depend on final smart data
3054     * pointer */
3055    if (type == ELM_WIN_INLINED_IMAGE)
3056      _win_inlined_image_set(sd);
3057
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))
3063      {
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);
3068      }
3069 #endif
3070
3071    else if (!strncmp(ENGINE_GET(), "shot:", 5))
3072      _shot_init(sd);
3073
3074    sd->kbdmode = ELM_WIN_KEYBOARD_UNKNOWN;
3075    sd->indmode = ELM_WIN_INDICATOR_UNKNOWN;
3076
3077 #ifdef HAVE_ELEMENTARY_X
3078    _elm_win_xwindow_get(sd);
3079    if (sd->x.xwin)
3080      {
3081         ecore_x_io_error_handler_set(_elm_x_io_err, NULL);
3082      }
3083 #endif
3084
3085 #ifdef HAVE_ELEMENTARY_WAYLAND
3086    if ((ENGINE_COMPARE(ELM_WAYLAND_SHM)) || (ENGINE_COMPARE(ELM_WAYLAND_EGL)))
3087      _elm_win_wlwindow_get(sd);
3088 #endif
3089
3090    if ((_elm_config->bgpixmap)
3091 #ifdef HAVE_ELEMENTARY_X
3092        &&
3093        (((sd->x.xwin) && (!ecore_x_screen_is_composited(0))) ||
3094            (!sd->x.xwin)))
3095 #else
3096       )
3097 #endif
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);
3102
3103    sd->type = type;
3104    sd->parent = parent;
3105
3106    if (sd->parent)
3107      evas_object_event_callback_add
3108        (sd->parent, EVAS_CALLBACK_DEL, _elm_win_on_parent_del, obj);
3109
3110    sd->evas = ecore_evas_get(sd->ee);
3111
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);
3117
3118    if (type == ELM_WIN_INLINED_IMAGE)
3119      elm_widget_parent2_set(obj, parent);
3120
3121    /* use own version of ecore_evas_object_associate() that does TRAP() */
3122    ecore_evas_data_set(sd->ee, "elm_win", obj);
3123
3124    evas_object_event_callback_add
3125      (obj, EVAS_CALLBACK_CHANGED_SIZE_HINTS,
3126       _elm_win_obj_callback_changed_size_hints, obj);
3127
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);
3140
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);
3151
3152    evas_image_cache_set(sd->evas, (_elm_config->image_cache * 1024));
3153    evas_font_cache_set(sd->evas, (_elm_config->font_cache * 1024));
3154
3155    EINA_LIST_FOREACH(_elm_config->font_dirs, l, fontpath)
3156      evas_font_path_append(sd->evas, fontpath);
3157
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);
3164
3165 #ifdef HAVE_ELEMENTARY_X
3166    _elm_win_xwin_update(sd);
3167 #endif
3168
3169    _elm_win_list = eina_list_append(_elm_win_list, obj);
3170    _elm_win_count++;
3171
3172    if (((fallback) && (!strcmp(fallback, "Software FB"))) ||
3173        ((!fallback) && (ENGINE_COMPARE(ELM_SOFTWARE_FB))))
3174      {
3175         TRAP(sd, fullscreen_set, 1);
3176      }
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");
3181
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);
3186
3187 #ifdef ELM_DEBUG
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);
3191
3192    if (evas_object_key_grab(obj, "F12", mask, 0, EINA_TRUE))
3193      INF("Ctrl+F12 key combination exclusive for dot tree generation\n");
3194    else
3195      ERR("failed to grab F12 key to elm widgets (dot) tree generation");
3196 #endif
3197
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))))))
3202      {
3203         Evas_Object *o;
3204         Evas_Coord mw = 1, mh = 1, hx = 0, hy = 0;
3205
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);
3216      }
3217    else if (_elm_config->softcursor_mode == ELM_SOFTCURSOR_MODE_OFF)
3218      {
3219         // do nothing
3220      }
3221
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.
3224
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);
3236 }
3237
3238 static void
3239 _constructor(Eo *obj, void *_pd EINA_UNUSED, va_list *list EINA_UNUSED)
3240 {
3241    eo_error_set(obj);
3242    ERR("only custom constructor can be used with '%s' class", MY_CLASS_NAME);
3243 }
3244
3245 EAPI Elm_Win_Type
3246 elm_win_type_get(const Evas_Object *obj)
3247 {
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));
3251    return ret;
3252 }
3253
3254 static void
3255 _type_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3256 {
3257    Elm_Win_Type *ret = va_arg(*list, Elm_Win_Type *);
3258    Elm_Win_Smart_Data *sd = _pd;
3259    *ret = sd->type;
3260 }
3261
3262 EAPI Evas_Object *
3263 elm_win_util_standard_add(const char *name,
3264                           const char *title)
3265 {
3266    Evas_Object *win, *bg;
3267
3268    win = elm_win_add(NULL, name, ELM_WIN_BASIC);
3269    if (!win) return NULL;
3270
3271    elm_win_title_set(win, title);
3272    bg = elm_bg_add(win);
3273    if (!bg)
3274      {
3275         evas_object_del(win);
3276         return NULL;
3277      }
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);
3281
3282    return win;
3283 }
3284
3285 EAPI void
3286 elm_win_resize_object_add(Evas_Object *obj,
3287                           Evas_Object *subobj)
3288 {
3289    ELM_WIN_CHECK(obj);
3290    eo_do(obj, elm_obj_win_resize_object_add(subobj));
3291 }
3292
3293 static void
3294 _resize_object_add(Eo *obj, void *_pd, va_list *list)
3295 {
3296    Evas_Object *subobj = va_arg(*list, Evas_Object *);
3297
3298    Elm_Win_Smart_Data *sd = _pd;
3299
3300    elm_widget_sub_object_add(obj, subobj);
3301
3302    if (!evas_object_box_append(sd->box, subobj))
3303      ERR("could not append %p to box", subobj);
3304 }
3305
3306 EAPI void
3307 elm_win_resize_object_del(Evas_Object *obj,
3308                           Evas_Object *subobj)
3309 {
3310    ELM_WIN_CHECK(obj);
3311    eo_do(obj, elm_obj_win_resize_object_del(subobj));
3312 }
3313
3314 static void
3315 _resize_object_del(Eo *obj, void *_pd, va_list *list)
3316 {
3317    Evas_Object *subobj = va_arg(*list, Evas_Object *);
3318    Elm_Win_Smart_Data *sd = _pd;
3319
3320    if (!elm_widget_sub_object_del(obj, subobj))
3321      ERR("could not remove sub object %p from %p", subobj, obj);
3322
3323    evas_object_box_remove(sd->box, subobj);
3324 }
3325
3326 EAPI void
3327 elm_win_title_set(Evas_Object *obj,
3328                   const char *title)
3329 {
3330    ELM_WIN_CHECK(obj);
3331    eo_do(obj, elm_obj_win_title_set(title));
3332 }
3333
3334 static void
3335 _title_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3336 {
3337    const char *title = va_arg(*list, const char *);
3338    Elm_Win_Smart_Data *sd = _pd;
3339
3340    if (!title) return;
3341    eina_stringshare_replace(&(sd->title), title);
3342    TRAP(sd, title_set, sd->title);
3343    if (sd->frame_obj)
3344      edje_object_part_text_escaped_set
3345        (sd->frame_obj, "elm.text.title", sd->title);
3346 }
3347
3348 EAPI const char *
3349 elm_win_title_get(const Evas_Object *obj)
3350 {
3351    ELM_WIN_CHECK(obj) NULL;
3352    const char *ret = NULL;
3353    eo_do((Eo *) obj, elm_obj_win_title_get(&ret));
3354    return ret;
3355 }
3356
3357 static void
3358 _title_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3359 {
3360    const char **ret = va_arg(*list, const char **);
3361    Elm_Win_Smart_Data *sd = _pd;
3362    *ret = sd->title;
3363 }
3364
3365 EAPI void
3366 elm_win_icon_name_set(Evas_Object *obj,
3367                       const char *icon_name)
3368 {
3369    ELM_WIN_CHECK(obj);
3370    eo_do(obj, elm_obj_win_icon_name_set(icon_name));
3371 }
3372
3373 static void
3374 _icon_name_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3375 {
3376    const char *icon_name = va_arg(*list, const char *);
3377    Elm_Win_Smart_Data *sd = _pd;
3378
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);
3383 #endif
3384 }
3385
3386 EAPI const char *
3387 elm_win_icon_name_get(const Evas_Object *obj)
3388 {
3389    ELM_WIN_CHECK(obj) NULL;
3390    const char *ret = NULL;
3391    eo_do((Eo *) obj, elm_obj_win_icon_name_get(&ret));
3392    return ret;
3393 }
3394
3395 static void
3396 _icon_name_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3397 {
3398    const char **ret = va_arg(*list, const char **);
3399    Elm_Win_Smart_Data *sd = _pd;
3400    *ret = sd->icon_name;
3401 }
3402
3403 EAPI void
3404 elm_win_role_set(Evas_Object *obj, const char *role)
3405 {
3406    ELM_WIN_CHECK(obj);
3407    eo_do(obj, elm_obj_win_role_set(role));
3408 }
3409
3410 static void
3411 _role_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3412 {
3413    const char *role = va_arg(*list, const char *);
3414    Elm_Win_Smart_Data *sd = _pd;
3415
3416    if (!role) return;
3417    eina_stringshare_replace(&(sd->role), role);
3418 #ifdef HAVE_ELEMENTARY_X
3419    _elm_win_xwin_update(sd);
3420 #endif
3421 }
3422
3423 EAPI const char *
3424 elm_win_role_get(const Evas_Object *obj)
3425 {
3426    ELM_WIN_CHECK(obj) NULL;
3427    const char *ret = NULL;
3428    eo_do((Eo *) obj, elm_obj_win_role_get(&ret));
3429    return ret;
3430 }
3431
3432 static void
3433 _role_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3434 {
3435    const char **ret = va_arg(*list, const char **);
3436    Elm_Win_Smart_Data *sd = _pd;
3437    *ret = sd->role;
3438 }
3439
3440 EAPI void
3441 elm_win_icon_object_set(Evas_Object *obj,
3442                         Evas_Object *icon)
3443 {
3444    ELM_WIN_CHECK(obj);
3445    eo_do(obj, elm_obj_win_icon_object_set(icon));
3446 }
3447
3448 static void
3449 _icon_object_set(Eo *obj, void *_pd, va_list *list)
3450 {
3451    Evas_Object *icon = va_arg(*list, Evas_Object *);
3452    Elm_Win_Smart_Data *sd = _pd;
3453
3454    if (sd->icon)
3455      evas_object_event_callback_del_full
3456        (sd->icon, EVAS_CALLBACK_DEL, _elm_win_on_icon_del, obj);
3457    sd->icon = icon;
3458    if (sd->icon)
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);
3463 #endif
3464 }
3465
3466 EAPI const Evas_Object *
3467 elm_win_icon_object_get(const Evas_Object *obj)
3468 {
3469    ELM_WIN_CHECK(obj) NULL;
3470    const Evas_Object *ret = NULL;
3471    eo_do((Eo *) obj, elm_obj_win_icon_object_get(&ret));
3472    return ret;
3473 }
3474
3475 static void
3476 _icon_object_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3477 {
3478    const Evas_Object **ret = va_arg(*list, const Evas_Object **);
3479    Elm_Win_Smart_Data *sd = _pd;
3480    *ret = sd->icon;
3481 }
3482
3483 EAPI void
3484 elm_win_autodel_set(Evas_Object *obj,
3485                     Eina_Bool autodel)
3486 {
3487    ELM_WIN_CHECK(obj);
3488    eo_do(obj, elm_obj_win_autodel_set(autodel));
3489 }
3490
3491 static void
3492 _autodel_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3493 {
3494    Eina_Bool autodel = va_arg(*list, int);
3495    Elm_Win_Smart_Data *sd = _pd;
3496    sd->autodel = autodel;
3497 }
3498
3499 EAPI Eina_Bool
3500 elm_win_autodel_get(const Evas_Object *obj)
3501 {
3502    ELM_WIN_CHECK(obj) EINA_FALSE;
3503    Eina_Bool ret = EINA_FALSE;
3504    eo_do((Eo *) obj, elm_obj_win_autodel_get(&ret));
3505    return ret;
3506 }
3507
3508 static void
3509 _autodel_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3510 {
3511    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3512    Elm_Win_Smart_Data *sd = _pd;
3513    *ret = sd->autodel;
3514 }
3515
3516 EAPI void
3517 elm_win_activate(Evas_Object *obj)
3518 {
3519    ELM_WIN_CHECK(obj);
3520    eo_do(obj, elm_obj_win_activate());
3521 }
3522
3523 static void
3524 _activate(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
3525 {
3526    Elm_Win_Smart_Data *sd = _pd;
3527    TRAP(sd, activate);
3528 }
3529
3530 EAPI void
3531 elm_win_lower(Evas_Object *obj)
3532 {
3533    ELM_WIN_CHECK(obj);
3534    eo_do(obj, elm_obj_win_lower());
3535 }
3536
3537 static void
3538 _lower(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
3539 {
3540    Elm_Win_Smart_Data *sd = _pd;
3541    TRAP(sd, lower);
3542 }
3543
3544 EAPI void
3545 elm_win_raise(Evas_Object *obj)
3546 {
3547    ELM_WIN_CHECK(obj);
3548    eo_do(obj, elm_obj_win_raise());
3549 }
3550
3551 static void
3552 _raise(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
3553 {
3554    Elm_Win_Smart_Data *sd = _pd;
3555    TRAP(sd, raise);
3556 }
3557
3558 EAPI void
3559 elm_win_center(Evas_Object *obj,
3560                Eina_Bool h,
3561                Eina_Bool v)
3562 {
3563    ELM_WIN_CHECK(obj);
3564    eo_do(obj, elm_obj_win_center(h, v));
3565 }
3566
3567 static void
3568 _center(Eo *obj, void *_pd, va_list *list)
3569 {
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;
3573
3574    Elm_Win_Smart_Data *sd = _pd;
3575
3576    if ((trap) && (trap->center) && (!trap->center(sd->trap_data, obj)))
3577      return;
3578
3579    ecore_evas_screen_geometry_get(sd->ee, NULL, NULL, &screen_w, &screen_h);
3580    if ((!screen_w) || (!screen_h)) return;
3581
3582    evas_object_geometry_get(obj, NULL, NULL, &win_w, &win_h);
3583    if ((!win_w) || (!win_h)) return;
3584
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;
3589    if (nx < 0) nx = 0;
3590    if (ny < 0) ny = 0;
3591
3592    evas_object_move(obj, nx, ny);
3593 }
3594
3595 EAPI void
3596 elm_win_borderless_set(Evas_Object *obj,
3597                        Eina_Bool borderless)
3598 {
3599    ELM_WIN_CHECK(obj);
3600    eo_do(obj, elm_obj_win_borderless_set(borderless));
3601 }
3602
3603 static void
3604 _borderless_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3605 {
3606    Eina_Bool borderless = va_arg(*list, int);
3607    Elm_Win_Smart_Data *sd = _pd;
3608
3609    Eina_Bool need_frame = EINA_FALSE;
3610
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)));
3615
3616    if (borderless)
3617      {
3618         if (need_frame)
3619           _elm_win_frame_del(sd);
3620      }
3621    else
3622      {
3623         if (need_frame)
3624           _elm_win_frame_add(sd, "default");
3625
3626         if (sd->frame_obj)
3627           evas_object_show(sd->frame_obj);
3628      }
3629
3630    TRAP(sd, borderless_set, borderless);
3631 #ifdef HAVE_ELEMENTARY_X
3632    _elm_win_xwin_update(sd);
3633 #endif
3634 }
3635
3636 EAPI Eina_Bool
3637 elm_win_borderless_get(const Evas_Object *obj)
3638 {
3639    ELM_WIN_CHECK(obj) EINA_FALSE;
3640    Eina_Bool ret = EINA_FALSE;
3641    eo_do((Eo *) obj, elm_obj_win_borderless_get(&ret));
3642    return ret;
3643 }
3644
3645 static void
3646 _borderless_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3647 {
3648    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3649    Elm_Win_Smart_Data *sd = _pd;
3650    *ret = ecore_evas_borderless_get(sd->ee);
3651 }
3652
3653 EAPI void
3654 elm_win_shaped_set(Evas_Object *obj,
3655                    Eina_Bool shaped)
3656 {
3657    ELM_WIN_CHECK(obj);
3658    eo_do(obj, elm_obj_win_shaped_set(shaped));
3659 }
3660
3661 static void
3662 _shaped_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3663 {
3664    Eina_Bool shaped = va_arg(*list, int);
3665    Elm_Win_Smart_Data *sd = _pd;
3666
3667    TRAP(sd, shaped_set, shaped);
3668 #ifdef HAVE_ELEMENTARY_X
3669    _elm_win_xwin_update(sd);
3670 #endif
3671 }
3672
3673 EAPI Eina_Bool
3674 elm_win_shaped_get(const Evas_Object *obj)
3675 {
3676    ELM_WIN_CHECK(obj) EINA_FALSE;
3677    Eina_Bool ret = EINA_FALSE;
3678    eo_do((Eo *) obj, elm_obj_win_shaped_get(&ret));
3679    return ret;
3680 }
3681
3682 static void
3683 _shaped_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3684 {
3685    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3686    Elm_Win_Smart_Data *sd = _pd;
3687    *ret = ecore_evas_shaped_get(sd->ee);
3688 }
3689
3690 EAPI void
3691 elm_win_alpha_set(Evas_Object *obj,
3692                   Eina_Bool enabled)
3693 {
3694    ELM_WIN_CHECK(obj);
3695    eo_do(obj, elm_obj_win_alpha_set(enabled));
3696 }
3697
3698 static void
3699 _alpha_set(Eo *obj, void *_pd, va_list *list)
3700 {
3701    Eina_Bool enabled = va_arg(*list, int);
3702    Elm_Win_Smart_Data *sd = _pd;
3703
3704    if (sd->img_obj)
3705      {
3706         evas_object_image_alpha_set(sd->img_obj, enabled);
3707         ecore_evas_alpha_set(sd->ee, enabled);
3708      }
3709    else
3710      {
3711 #ifdef HAVE_ELEMENTARY_X
3712         if (sd->x.xwin)
3713           {
3714              if (enabled)
3715                {
3716                   if (!ecore_x_screen_is_composited(0))
3717                     elm_win_shaped_set(obj, enabled);
3718                   else
3719                     TRAP(sd, alpha_set, enabled);
3720                }
3721              else
3722                TRAP(sd, alpha_set, enabled);
3723              _elm_win_xwin_update(sd);
3724           }
3725         else
3726 #endif
3727           TRAP(sd, alpha_set, enabled);
3728      }
3729 }
3730
3731 EAPI Eina_Bool
3732 elm_win_alpha_get(const Evas_Object *obj)
3733 {
3734    ELM_WIN_CHECK(obj) EINA_FALSE;
3735    Eina_Bool ret = EINA_FALSE;
3736    eo_do((Eo *) obj, elm_obj_win_alpha_get(&ret));
3737    return ret;
3738 }
3739
3740 static void
3741 _alpha_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3742 {
3743    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3744    Elm_Win_Smart_Data *sd = _pd;
3745
3746    if (sd->img_obj)
3747      {
3748         *ret = evas_object_image_alpha_get(sd->img_obj);
3749      }
3750    else
3751      {
3752         *ret = ecore_evas_alpha_get(sd->ee);
3753      }
3754 }
3755
3756 EAPI void
3757 elm_win_override_set(Evas_Object *obj,
3758                      Eina_Bool override)
3759 {
3760    ELM_WIN_CHECK(obj);
3761    eo_do(obj, elm_obj_win_override_set(override));
3762 }
3763
3764 static void
3765 _override_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3766 {
3767    Eina_Bool override = va_arg(*list, int);
3768    Elm_Win_Smart_Data *sd = _pd;
3769
3770    TRAP(sd, override_set, override);
3771 #ifdef HAVE_ELEMENTARY_X
3772    _elm_win_xwin_update(sd);
3773 #endif
3774 }
3775
3776 EAPI Eina_Bool
3777 elm_win_override_get(const Evas_Object *obj)
3778 {
3779    ELM_WIN_CHECK(obj) EINA_FALSE;
3780    Eina_Bool ret = EINA_FALSE;
3781    eo_do((Eo *) obj, elm_obj_win_override_get(&ret));
3782    return ret;
3783 }
3784
3785 static void
3786 _override_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3787 {
3788    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3789    Elm_Win_Smart_Data *sd = _pd;
3790    *ret = ecore_evas_override_get(sd->ee);
3791 }
3792
3793 EAPI void
3794 elm_win_fullscreen_set(Evas_Object *obj,
3795                        Eina_Bool fullscreen)
3796 {
3797    ELM_WIN_CHECK(obj);
3798    eo_do(obj, elm_obj_win_fullscreen_set(fullscreen));
3799 }
3800
3801 static void
3802 _fullscreen_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3803 {
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))
3809      {
3810         // these engines... can ONLY be fullscreen
3811         return;
3812      }
3813    else
3814      {
3815 //        sd->fullscreen = fullscreen;
3816
3817         Eina_Bool need_frame = EINA_FALSE;
3818
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)));
3823
3824         TRAP(sd, fullscreen_set, fullscreen);
3825
3826         if (fullscreen)
3827           {
3828              if (need_frame)
3829                _elm_win_frame_del(sd);
3830           }
3831         else
3832           {
3833              if (need_frame)
3834                _elm_win_frame_add(sd, "default");
3835
3836              if (sd->frame_obj)
3837                evas_object_show(sd->frame_obj);
3838           }
3839 #ifdef HAVE_ELEMENTARY_X
3840         _elm_win_xwin_update(sd);
3841 #endif
3842      }
3843 }
3844
3845 EAPI Eina_Bool
3846 elm_win_fullscreen_get(const Evas_Object *obj)
3847 {
3848    ELM_WIN_CHECK(obj) EINA_FALSE;
3849    Eina_Bool ret = EINA_FALSE;
3850    eo_do((Eo *) obj, elm_obj_win_fullscreen_get(&ret));
3851    return ret;
3852 }
3853
3854 static void
3855 _fullscreen_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3856 {
3857    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3858    Elm_Win_Smart_Data *sd = _pd;
3859
3860    if (!ret) return;
3861
3862    const char* engine_name = ecore_evas_engine_name_get(sd->ee);
3863
3864    if (engine_name &&
3865        ((!strcmp(engine_name, ELM_SOFTWARE_FB)) ||
3866         (!strcmp(engine_name, ELM_SOFTWARE_16_WINCE))))
3867      {
3868         // these engines... can ONLY be fullscreen
3869         *ret = EINA_TRUE;
3870      }
3871    else
3872      {
3873         *ret = sd->fullscreen;
3874      }
3875 }
3876
3877 EAPI Evas_Object *
3878 elm_win_main_menu_get(const Evas_Object *obj)
3879 {
3880    ELM_WIN_CHECK(obj) NULL;
3881    Evas_Object *ret;
3882    eo_do((Eo *) obj, elm_obj_win_main_menu_get(&ret));
3883    return ret;
3884 }
3885
3886 static void
3887 _dbus_menu_set(Eina_Bool dbus_connect, void *data)
3888 {
3889    ELM_WIN_DATA_GET_OR_RETURN(data, sd);
3890
3891    if (dbus_connect)
3892      {
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);
3897      }
3898    else
3899      {
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);
3904      }
3905 }
3906
3907 static void
3908 _main_menu_get(Eo *obj, void *_pd, va_list *list)
3909 {
3910    Eo **ret = va_arg(*list, Eo **);
3911    Elm_Win_Smart_Data *sd = _pd;
3912    Eina_Bool use_dbus = EINA_FALSE;
3913
3914    if (sd->main_menu) goto end;
3915
3916    sd->main_menu = elm_menu_add(obj);
3917    _elm_menu_menu_bar_set(sd->main_menu, EINA_TRUE);
3918
3919 #ifdef HAVE_ELEMENTARY_X
3920    if (!_elm_config->disable_external_menu && sd->x.xwin) use_dbus = EINA_TRUE;
3921 #endif
3922
3923 #ifdef HAVE_ELEMENTARY_X
3924    if (use_dbus && _elm_dbus_menu_register(sd->main_menu))
3925      {
3926         _elm_dbus_menu_app_menu_register(sd->x.xwin, sd->main_menu,
3927                                          _dbus_menu_set, obj);
3928      }
3929    else
3930 #endif
3931      _dbus_menu_set(EINA_FALSE, obj);
3932
3933 end:
3934    *ret = sd->main_menu;
3935 }
3936
3937 EAPI void
3938 elm_win_maximized_set(Evas_Object *obj,
3939                       Eina_Bool maximized)
3940 {
3941    ELM_WIN_CHECK(obj);
3942    eo_do(obj, elm_obj_win_maximized_set(maximized));
3943 }
3944
3945 static void
3946 _maximized_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3947 {
3948    Eina_Bool maximized = va_arg(*list, int);
3949    Elm_Win_Smart_Data *sd = _pd;
3950
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);
3956 #endif
3957 }
3958
3959 EAPI Eina_Bool
3960 elm_win_maximized_get(const Evas_Object *obj)
3961 {
3962    ELM_WIN_CHECK(obj) EINA_FALSE;
3963    Eina_Bool ret = EINA_FALSE;
3964    eo_do((Eo *) obj, elm_obj_win_maximized_get(&ret));
3965    return ret;
3966 }
3967
3968 static void
3969 _maximized_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3970 {
3971    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
3972    Elm_Win_Smart_Data *sd = _pd;
3973    *ret = sd->maximized;
3974 }
3975
3976 EAPI void
3977 elm_win_iconified_set(Evas_Object *obj,
3978                       Eina_Bool iconified)
3979 {
3980    ELM_WIN_CHECK(obj);
3981    eo_do(obj, elm_obj_win_iconified_set(iconified));
3982 }
3983
3984 static void
3985 _iconified_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
3986 {
3987    Eina_Bool iconified = va_arg(*list, int);
3988    Elm_Win_Smart_Data *sd = _pd;
3989
3990 //   sd->iconified = iconified;
3991    TRAP(sd, iconified_set, iconified);
3992 #ifdef HAVE_ELEMENTARY_X
3993    _elm_win_xwin_update(sd);
3994 #endif
3995 }
3996
3997 EAPI Eina_Bool
3998 elm_win_iconified_get(const Evas_Object *obj)
3999 {
4000    ELM_WIN_CHECK(obj) EINA_FALSE;
4001    Eina_Bool ret = EINA_FALSE;
4002    eo_do((Eo *) obj, elm_obj_win_iconified_get(&ret));
4003    return ret;
4004 }
4005
4006 static void
4007 _iconified_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4008 {
4009    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4010    Elm_Win_Smart_Data *sd = _pd;
4011    *ret = sd->iconified;
4012 }
4013
4014 EAPI void
4015 elm_win_withdrawn_set(Evas_Object *obj,
4016                       Eina_Bool withdrawn)
4017 {
4018    ELM_WIN_CHECK(obj);
4019    eo_do(obj, elm_obj_win_withdrawn_set(withdrawn));
4020 }
4021
4022 static void
4023 _withdrawn_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4024 {
4025    Eina_Bool withdrawn = va_arg(*list, int);
4026    Elm_Win_Smart_Data *sd = _pd;
4027
4028 //   sd->withdrawn = withdrawn;
4029    TRAP(sd, withdrawn_set, withdrawn);
4030 #ifdef HAVE_ELEMENTARY_X
4031    _elm_win_xwin_update(sd);
4032 #endif
4033 }
4034
4035 EAPI Eina_Bool
4036 elm_win_withdrawn_get(const Evas_Object *obj)
4037 {
4038    ELM_WIN_CHECK(obj) EINA_FALSE;
4039    Eina_Bool ret = EINA_FALSE;
4040    eo_do((Eo *) obj, elm_obj_win_withdrawn_get(&ret));
4041    return ret;
4042 }
4043
4044 static void
4045 _withdrawn_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4046 {
4047    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4048    Elm_Win_Smart_Data *sd = _pd;
4049    *ret = sd->withdrawn;
4050 }
4051
4052 EAPI void
4053 elm_win_available_profiles_set(Evas_Object  *obj,
4054                                const char  **profiles,
4055                                unsigned int  count)
4056 {
4057    ELM_WIN_CHECK(obj);
4058    eo_do((Eo *) obj, elm_obj_win_available_profiles_set(profiles, count));
4059 }
4060
4061 static void
4062 _available_profiles_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4063 {
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;
4068
4069    _elm_win_available_profiles_del(sd);
4070    if ((profiles) && (count >= 1))
4071      {
4072         sd->profile.available_list = calloc(count, sizeof(char *));
4073         if (sd->profile.available_list)
4074           {
4075              if (!sd->profile.name) found = EINA_TRUE;
4076
4077              unsigned int i;
4078              for (i = 0; i < count; i++)
4079                {
4080                   sd->profile.available_list[i] = eina_stringshare_add(profiles[i]);
4081
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])))
4085                     {
4086                        found = EINA_TRUE;
4087                     }
4088                }
4089              sd->profile.count = count;
4090           }
4091      }
4092
4093    if (ecore_evas_window_profile_supported_get(sd->ee))
4094      {
4095         ecore_evas_window_available_profiles_set(sd->ee,
4096                                                  sd->profile.available_list,
4097                                                  sd->profile.count);
4098
4099         /* current profile of elm_win is wrong, change profile */
4100         if ((sd->profile.available_list) && (!found))
4101           {
4102              eina_stringshare_replace(&(sd->profile.name),
4103                                       sd->profile.available_list[0]);
4104              ecore_evas_window_profile_set(sd->ee, sd->profile.name);
4105           }
4106
4107      }
4108    else
4109      {
4110         if (sd->profile.available_list)
4111           _elm_win_profile_update(sd);
4112      }
4113 }
4114
4115 EAPI Eina_Bool
4116 elm_win_available_profiles_get(Evas_Object   *obj,
4117                                char        ***profiles,
4118                                unsigned int  *count)
4119 {
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));
4123    return ret;
4124 }
4125
4126 static void
4127 _available_profiles_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4128 {
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;
4133    Eina_Bool res;
4134
4135    if (ecore_evas_window_profile_supported_get(sd->ee))
4136      {
4137         res = ecore_evas_window_available_profiles_get(sd->ee,
4138                                                        profiles,
4139                                                        count);
4140      }
4141    else
4142      {
4143         if (profiles) *profiles = (char **)sd->profile.available_list;
4144         if (count) *count = sd->profile.count;
4145         res = EINA_TRUE;
4146      }
4147    if (ret) *ret = res;
4148 }
4149
4150 EAPI void
4151 elm_win_profile_set(Evas_Object *obj,
4152                     const char *profile)
4153 {
4154    ELM_WIN_CHECK(obj);
4155    eo_do((Eo *) obj, elm_obj_win_profile_set(profile));
4156 }
4157
4158 static void
4159 _profile_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4160 {
4161    const char *profile = va_arg(*list, const char *);
4162    Elm_Win_Smart_Data *sd = _pd;
4163
4164    /* check to see if a given profile is present in an available profiles */
4165    if ((profile) && (sd->profile.available_list))
4166      {
4167         Eina_Bool found = EINA_FALSE;
4168         unsigned int i;
4169         for (i = 0; i < sd->profile.count; i++)
4170           {
4171              if (!strcmp(profile,
4172                          sd->profile.available_list[i]))
4173                {
4174                   found = EINA_TRUE;
4175                   break;
4176                }
4177           }
4178         if (!found) return;
4179      }
4180
4181    if (ecore_evas_window_profile_supported_get(sd->ee))
4182      {
4183         if (!profile) _elm_win_profile_del(sd);
4184         ecore_evas_window_profile_set(sd->ee, profile);
4185      }
4186    else
4187      {
4188         if (_elm_win_profile_set(sd, profile))
4189           _elm_win_profile_update(sd);
4190      }
4191 }
4192
4193 EAPI const char *
4194 elm_win_profile_get(const Evas_Object *obj)
4195 {
4196    ELM_WIN_CHECK(obj) NULL;
4197    const char *ret = NULL;
4198    eo_do((Eo *) obj, elm_obj_win_profile_get(&ret));
4199    return ret;
4200 }
4201
4202 static void
4203 _profile_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4204 {
4205    const char **ret = va_arg(*list, const char **);
4206    Elm_Win_Smart_Data *sd = _pd;
4207    *ret = sd->profile.name;
4208 }
4209
4210 EAPI void
4211 elm_win_urgent_set(Evas_Object *obj,
4212                    Eina_Bool urgent)
4213 {
4214    ELM_WIN_CHECK(obj);
4215    eo_do(obj, elm_obj_win_urgent_set(urgent));
4216 }
4217
4218 static void
4219 _urgent_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4220 {
4221    Eina_Bool urgent = va_arg(*list, int);
4222    Elm_Win_Smart_Data *sd = _pd;
4223
4224    sd->urgent = urgent;
4225    TRAP(sd, urgent_set, urgent);
4226 #ifdef HAVE_ELEMENTARY_X
4227    _elm_win_xwin_update(sd);
4228 #endif
4229 }
4230
4231 EAPI Eina_Bool
4232 elm_win_urgent_get(const Evas_Object *obj)
4233 {
4234    ELM_WIN_CHECK(obj) EINA_FALSE;
4235    Eina_Bool ret = EINA_FALSE;
4236    eo_do((Eo *) obj, elm_obj_win_urgent_get(&ret));
4237    return ret;
4238 }
4239
4240 static void
4241 _urgent_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4242 {
4243    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4244    Elm_Win_Smart_Data *sd = _pd;
4245    *ret = sd->urgent;
4246 }
4247
4248 EAPI void
4249 elm_win_demand_attention_set(Evas_Object *obj,
4250                              Eina_Bool demand_attention)
4251 {
4252    ELM_WIN_CHECK(obj);
4253    eo_do(obj, elm_obj_win_demand_attention_set(demand_attention));
4254 }
4255
4256 static void
4257 _demand_attention_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4258 {
4259    Eina_Bool demand_attention = va_arg(*list, int);
4260    Elm_Win_Smart_Data *sd = _pd;
4261
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);
4266 #endif
4267 }
4268
4269 EAPI Eina_Bool
4270 elm_win_demand_attention_get(const Evas_Object *obj)
4271 {
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));
4275    return ret;
4276 }
4277
4278 static void
4279 _demand_attention_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4280 {
4281    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4282    Elm_Win_Smart_Data *sd = _pd;
4283    *ret = sd->demand_attention;
4284 }
4285
4286 EAPI void
4287 elm_win_modal_set(Evas_Object *obj,
4288                   Eina_Bool modal)
4289 {
4290    ELM_WIN_CHECK(obj);
4291    eo_do(obj, elm_obj_win_modal_set(modal));
4292 }
4293
4294 static void
4295 _modal_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4296 {
4297    Eina_Bool modal = va_arg(*list, int);
4298    Elm_Win_Smart_Data *sd = _pd;
4299
4300    sd->modal = modal;
4301    TRAP(sd, modal_set, modal);
4302 #ifdef HAVE_ELEMENTARY_X
4303    _elm_win_xwin_update(sd);
4304 #endif
4305 }
4306
4307 EAPI Eina_Bool
4308 elm_win_modal_get(const Evas_Object *obj)
4309 {
4310    ELM_WIN_CHECK(obj) EINA_FALSE;
4311    Eina_Bool ret = EINA_FALSE;
4312    eo_do((Eo *) obj, elm_obj_win_modal_get(&ret));
4313    return ret;
4314 }
4315
4316 static void
4317 _modal_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4318 {
4319    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4320    Elm_Win_Smart_Data *sd = _pd;
4321    *ret = sd->modal;
4322 }
4323
4324 EAPI void
4325 elm_win_aspect_set(Evas_Object *obj,
4326                    double aspect)
4327 {
4328    ELM_WIN_CHECK(obj);
4329    eo_do(obj, elm_obj_win_aspect_set(aspect));
4330 }
4331
4332 static void
4333 _aspect_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4334 {
4335    double aspect = va_arg(*list, double);
4336    Elm_Win_Smart_Data *sd = _pd;
4337
4338    sd->aspect = aspect;
4339    TRAP(sd, aspect_set, aspect);
4340 #ifdef HAVE_ELEMENTARY_X
4341    _elm_win_xwin_update(sd);
4342 #endif
4343 }
4344
4345 EAPI double
4346 elm_win_aspect_get(const Evas_Object *obj)
4347 {
4348    ELM_WIN_CHECK(obj) 0.0;
4349    double ret = 0.0;
4350    eo_do((Eo *) obj, elm_obj_win_aspect_get(&ret));
4351    return ret;
4352 }
4353
4354 static void
4355 _aspect_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4356 {
4357    double *ret = va_arg(*list, double *);
4358    Elm_Win_Smart_Data *sd = _pd;
4359    *ret = sd->aspect;
4360 }
4361
4362 EAPI void
4363 elm_win_size_base_set(Evas_Object *obj, int w, int h)
4364 {
4365    ELM_WIN_CHECK(obj);
4366    eo_do(obj, elm_obj_win_size_base_set(w, h));
4367 }
4368
4369 static void
4370 _size_base_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4371 {
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);
4380 #endif
4381 }
4382
4383 EAPI void
4384 elm_win_size_base_get(Evas_Object *obj, int *w, int *h)
4385 {
4386    ELM_WIN_CHECK(obj);
4387    eo_do(obj, elm_obj_win_size_base_get(w, h));
4388 }
4389
4390 static void
4391 _size_base_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4392 {
4393    int *w = va_arg(*list, int *);
4394    int *h = va_arg(*list, int *);
4395
4396    Elm_Win_Smart_Data *sd = _pd;
4397    if (w) *w = sd->size_base_w;
4398    if (w) *h = sd->size_base_h;
4399 }
4400
4401 EAPI void
4402 elm_win_size_step_set(Evas_Object *obj, int w, int h)
4403 {
4404    ELM_WIN_CHECK(obj);
4405    eo_do(obj, elm_obj_win_size_step_set(w, h));
4406 }
4407
4408 static void
4409 _size_step_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4410 {
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);
4419 #endif
4420 }
4421
4422 EAPI void
4423 elm_win_size_step_get(Evas_Object *obj, int *w, int *h)
4424 {
4425    ELM_WIN_CHECK(obj);
4426    eo_do(obj, elm_obj_win_size_step_get(w, h));
4427 }
4428
4429 static void
4430 _size_step_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4431 {
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;
4437 }
4438
4439 EAPI void
4440 elm_win_layer_set(Evas_Object *obj,
4441                   int layer)
4442 {
4443    ELM_WIN_CHECK(obj);
4444    eo_do(obj, elm_obj_win_layer_set(layer));
4445 }
4446
4447 static void
4448 _layer_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4449 {
4450    int layer = va_arg(*list, int);
4451    Elm_Win_Smart_Data *sd = _pd;
4452
4453    TRAP(sd, layer_set, layer);
4454 #ifdef HAVE_ELEMENTARY_X
4455    _elm_win_xwin_update(sd);
4456 #endif
4457 }
4458
4459 EAPI int
4460 elm_win_layer_get(const Evas_Object *obj)
4461 {
4462    ELM_WIN_CHECK(obj) - 1;
4463    int ret = - 1;
4464    eo_do((Eo *) obj, elm_obj_win_layer_get(&ret));
4465    return ret;
4466 }
4467
4468 static void
4469 _layer_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4470 {
4471    int *ret = va_arg(*list, int *);
4472    Elm_Win_Smart_Data *sd = _pd;
4473    *ret = ecore_evas_layer_get(sd->ee);
4474 }
4475
4476 EAPI void
4477 elm_win_norender_push(Evas_Object *obj)
4478 {
4479    ELM_WIN_CHECK(obj);
4480    ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
4481
4482    sd->norender++;
4483    if (sd->norender == 1) ecore_evas_manual_render_set(sd->ee, EINA_TRUE);
4484 }
4485
4486 EAPI void
4487 elm_win_norender_pop(Evas_Object *obj)
4488 {
4489    ELM_WIN_CHECK(obj);
4490    ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
4491
4492    if (sd->norender <= 0) return;
4493    sd->norender--;
4494    if (sd->norender == 0) ecore_evas_manual_render_set(sd->ee, EINA_FALSE);
4495 }
4496
4497 EAPI int
4498 elm_win_norender_get(Evas_Object *obj)
4499 {
4500    ELM_WIN_CHECK(obj) - 1;
4501    ELM_WIN_DATA_GET_OR_RETURN_VAL(obj, sd, -1);
4502    return sd->norender;
4503 }
4504
4505 EAPI void
4506 elm_win_render(Evas_Object *obj)
4507 {
4508    ELM_WIN_CHECK(obj);
4509    ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
4510    ecore_evas_manual_render(sd->ee);
4511 }
4512
4513 static int
4514 _win_rotation_degree_check(int rotation)
4515 {
4516    if ((rotation > 360) || (rotation < 0))
4517      {
4518         WRN("Rotation degree should be 0 ~ 360 (passed degree: %d)", rotation);
4519         rotation %= 360;
4520         if (rotation < 0) rotation += 360;
4521      }
4522    return rotation;
4523 }
4524
4525 /*
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.
4528  */
4529 EAPI void
4530 elm_win_rotation_set(Evas_Object *obj,
4531                      int rotation)
4532 {
4533    ELM_WIN_CHECK(obj);
4534    eo_do(obj, elm_obj_win_rotation_set(rotation));
4535 }
4536
4537 static void
4538 _win_rotate(Evas_Object *obj, Elm_Win_Smart_Data *sd, int rotation, Eina_Bool resize)
4539 {
4540    rotation = _win_rotation_degree_check(rotation);
4541    if (sd->rot == rotation) return;
4542    sd->rot = rotation;
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);
4550 #endif
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);
4554 }
4555
4556 static void
4557 _rotation_set(Eo *obj, void *_pd, va_list *list)
4558 {
4559    int rotation = va_arg(*list, int);
4560    Elm_Win_Smart_Data *sd = _pd;
4561    _win_rotate(obj, sd, rotation, EINA_FALSE);
4562 }
4563
4564 /*
4565  * This API does not resize the internal window (ex: X window).
4566  * But this resizes evas_output, elm window, and its contents.
4567  */
4568 EAPI void
4569 elm_win_rotation_with_resize_set(Evas_Object *obj,
4570                                  int rotation)
4571 {
4572    ELM_WIN_CHECK(obj);
4573    eo_do(obj, elm_obj_win_rotation_with_resize_set(rotation));
4574 }
4575
4576 static void
4577 _rotation_with_resize_set(Eo *obj, void *_pd, va_list *list)
4578 {
4579    int rotation = va_arg(*list, int);
4580    Elm_Win_Smart_Data *sd = _pd;
4581    _win_rotate(obj, sd, rotation, EINA_TRUE);
4582 }
4583
4584 EAPI int
4585 elm_win_rotation_get(const Evas_Object *obj)
4586 {
4587    ELM_WIN_CHECK(obj) - 1;
4588    int ret = - 1;
4589    eo_do((Eo *) obj, elm_obj_win_rotation_get(&ret));
4590    return ret;
4591 }
4592
4593 static void
4594 _rotation_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4595 {
4596    int *ret = va_arg(*list, int *);
4597    Elm_Win_Smart_Data *sd = _pd;
4598    *ret = sd->rot;
4599 }
4600
4601 EAPI Eina_Bool
4602 elm_win_wm_rotation_supported_get(const Evas_Object *obj)
4603 {
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));
4607    return ret;
4608 }
4609
4610 static void
4611 _wm_rotation_supported_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4612 {
4613    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4614    Elm_Win_Smart_Data *sd = _pd;
4615    *ret = sd->wm_rot.wm_supported;
4616 }
4617
4618 /* This will unset a preferred rotation, if given preferred rotation is '-1'.
4619  */
4620 EAPI void
4621 elm_win_wm_rotation_preferred_rotation_set(const Evas_Object *obj,
4622                                            int rotation)
4623 {
4624    ELM_WIN_CHECK(obj);
4625    eo_do((Eo *) obj, elm_obj_win_wm_preferred_rotation_set(rotation));
4626 }
4627
4628 static void
4629 _wm_preferred_rotation_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4630 {
4631    int rotation = va_arg(*list, int);
4632    int rot;
4633    Elm_Win_Smart_Data *sd = _pd;
4634
4635    if (!sd->wm_rot.use)
4636      sd->wm_rot.use = EINA_TRUE;
4637
4638    // '-1' means that elm_win doesn't use preferred rotation.
4639    if (rotation == -1)
4640      rot = -1;
4641    else
4642      rot = _win_rotation_degree_check(rotation);
4643
4644    if (sd->wm_rot.preferred_rot == rot) return;
4645    sd->wm_rot.preferred_rot = rot;
4646
4647    ecore_evas_wm_rotation_preferred_rotation_set(sd->ee, rot);
4648 }
4649
4650 EAPI int
4651 elm_win_wm_rotation_preferred_rotation_get(const Evas_Object *obj)
4652 {
4653    ELM_WIN_CHECK(obj) -1;
4654    int ret = -1;
4655    eo_do((Eo *) obj, elm_obj_win_wm_preferred_rotation_get(&ret));
4656    return ret;
4657 }
4658
4659 static void
4660 _wm_preferred_rotation_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4661 {
4662    int *ret = va_arg(*list, int *);
4663    Elm_Win_Smart_Data *sd = _pd;
4664    *ret = sd->wm_rot.preferred_rot;
4665 }
4666
4667 EAPI void
4668 elm_win_wm_rotation_available_rotations_set(Evas_Object *obj,
4669                                             const int   *rotations,
4670                                             unsigned int count)
4671 {
4672    ELM_WIN_CHECK(obj);
4673    eo_do((Eo *) obj, elm_obj_win_wm_available_rotations_set(rotations, count));
4674 }
4675
4676 static void
4677 _wm_available_rotations_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4678 {
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;
4682    unsigned int i;
4683    int r;
4684
4685    if (!sd->wm_rot.use)
4686      sd->wm_rot.use = EINA_TRUE;
4687
4688    ELM_SAFE_FREE(sd->wm_rot.rots, free);
4689    sd->wm_rot.count = 0;
4690
4691    if (count > 0)
4692      {
4693         sd->wm_rot.rots = calloc(count, sizeof(int));
4694         if (!sd->wm_rot.rots) return;
4695         for (i = 0; i < count; i++)
4696           {
4697              r = _win_rotation_degree_check(rotations[i]);
4698              sd->wm_rot.rots[i] = r;
4699           }
4700      }
4701
4702    sd->wm_rot.count = count;
4703
4704    ecore_evas_wm_rotation_available_rotations_set(sd->ee,
4705                                                   sd->wm_rot.rots,
4706                                                   sd->wm_rot.count);
4707 }
4708
4709 EAPI Eina_Bool
4710 elm_win_wm_rotation_available_rotations_get(const Evas_Object *obj,
4711                                             int              **rotations,
4712                                             unsigned int      *count)
4713 {
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));
4717    return ret;
4718 }
4719
4720 static void
4721 _wm_available_rotations_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4722 {
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;
4727    *ret = EINA_FALSE;
4728    if (!sd->wm_rot.use) return;
4729
4730    if (sd->wm_rot.count > 0)
4731      {
4732         if (rotations)
4733           {
4734              *rotations = calloc(sd->wm_rot.count, sizeof(int));
4735              if (*rotations)
4736                {
4737                   memcpy(*rotations,
4738                          sd->wm_rot.rots,
4739                          sizeof(int) * sd->wm_rot.count);
4740                }
4741           }
4742      }
4743
4744    if (count) *count = sd->wm_rot.count;
4745    *ret = EINA_TRUE;
4746 }
4747
4748 EAPI void
4749 elm_win_wm_rotation_manual_rotation_done_set(Evas_Object *obj,
4750                                              Eina_Bool    set)
4751 {
4752    ELM_WIN_CHECK(obj);
4753    eo_do((Eo *) obj, elm_obj_win_wm_manual_rotation_done_set(set));
4754 }
4755
4756 static void
4757 _wm_manual_rotation_done_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4758 {
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);
4763 }
4764
4765 EAPI Eina_Bool
4766 elm_win_wm_rotation_manual_rotation_done_get(const Evas_Object *obj)
4767 {
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));
4771    return ret;
4772 }
4773
4774 static void
4775 _wm_manual_rotation_done_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4776 {
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);
4781 }
4782
4783 EAPI void
4784 elm_win_wm_rotation_manual_rotation_done(Evas_Object *obj)
4785 {
4786    ELM_WIN_CHECK(obj);
4787    eo_do((Eo *) obj, elm_obj_win_wm_manual_rotation_done());
4788 }
4789
4790 static void
4791 _wm_manual_rotation_done(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
4792 {
4793    Elm_Win_Smart_Data *sd = _pd;
4794    if (!sd->wm_rot.use) return;
4795    ecore_evas_wm_rotation_manual_rotation_done(sd->ee);
4796 }
4797
4798 EAPI void
4799 elm_win_sticky_set(Evas_Object *obj,
4800                    Eina_Bool sticky)
4801 {
4802    ELM_WIN_CHECK(obj);
4803    eo_do(obj, elm_obj_win_sticky_set(sticky));
4804 }
4805
4806 static void
4807 _sticky_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4808 {
4809    Eina_Bool sticky = va_arg(*list, int);
4810    Elm_Win_Smart_Data *sd = _pd;
4811
4812 //   sd->sticky = sticky;
4813    TRAP(sd, sticky_set, sticky);
4814 #ifdef HAVE_ELEMENTARY_X
4815    _elm_win_xwin_update(sd);
4816 #endif
4817 }
4818
4819 EAPI Eina_Bool
4820 elm_win_sticky_get(const Evas_Object *obj)
4821 {
4822    ELM_WIN_CHECK(obj) EINA_FALSE;
4823    Eina_Bool ret = EINA_FALSE;
4824    eo_do((Eo *) obj, elm_obj_win_sticky_get(&ret));
4825    return ret;
4826 }
4827
4828 static void
4829 _sticky_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4830 {
4831    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4832    Elm_Win_Smart_Data *sd = _pd;
4833    *ret = sd->sticky;
4834 }
4835
4836 EAPI void
4837 elm_win_keyboard_mode_set(Evas_Object *obj,
4838                           Elm_Win_Keyboard_Mode mode)
4839 {
4840    ELM_WIN_CHECK(obj);
4841    eo_do(obj, elm_obj_win_keyboard_mode_set(mode));
4842 }
4843
4844 static void
4845 _keyboard_mode_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4846 {
4847    Elm_Win_Keyboard_Mode mode = va_arg(*list, Elm_Win_Keyboard_Mode);
4848    Elm_Win_Smart_Data *sd = _pd;
4849
4850    if (mode == sd->kbdmode) return;
4851 #ifdef HAVE_ELEMENTARY_X
4852    _elm_win_xwindow_get(sd);
4853 #endif
4854    sd->kbdmode = mode;
4855 #ifdef HAVE_ELEMENTARY_X
4856    if (sd->x.xwin)
4857      ecore_x_e_virtual_keyboard_state_set
4858        (sd->x.xwin, (Ecore_X_Virtual_Keyboard_State)sd->kbdmode);
4859 #endif
4860 }
4861
4862 EAPI Elm_Win_Keyboard_Mode
4863 elm_win_keyboard_mode_get(const Evas_Object *obj)
4864 {
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));
4868    return ret;
4869 }
4870
4871 static void
4872 _keyboard_mode_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4873 {
4874    Elm_Win_Keyboard_Mode *ret = va_arg(*list, Elm_Win_Keyboard_Mode *);
4875    Elm_Win_Smart_Data *sd = _pd;
4876    *ret = sd->kbdmode;
4877 }
4878
4879 EAPI void
4880 elm_win_keyboard_win_set(Evas_Object *obj,
4881                          Eina_Bool is_keyboard)
4882 {
4883    ELM_WIN_CHECK(obj);
4884    eo_do(obj, elm_obj_win_keyboard_win_set(is_keyboard));
4885 }
4886
4887 static void
4888 _keyboard_win_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4889 {
4890    Eina_Bool is_keyboard = va_arg(*list, int);
4891    Elm_Win_Smart_Data *sd = _pd;
4892
4893 #ifdef HAVE_ELEMENTARY_X
4894    _elm_win_xwindow_get(sd);
4895    if (sd->x.xwin)
4896      ecore_x_e_virtual_keyboard_set(sd->x.xwin, is_keyboard);
4897 #else
4898    (void)is_keyboard;
4899 #endif
4900 }
4901
4902 EAPI Eina_Bool
4903 elm_win_keyboard_win_get(const Evas_Object *obj)
4904 {
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));
4908    return ret;
4909 }
4910
4911 static void
4912 _keyboard_win_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4913 {
4914    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
4915    Elm_Win_Smart_Data *sd = _pd;
4916
4917 #ifdef HAVE_ELEMENTARY_X
4918    _elm_win_xwindow_get(sd);
4919    if (sd->x.xwin)
4920      {
4921         *ret = ecore_x_e_virtual_keyboard_get(sd->x.xwin);
4922         return;
4923      }
4924 #endif
4925    *ret = EINA_FALSE;
4926 }
4927
4928 EAPI void
4929 elm_win_indicator_mode_set(Evas_Object *obj,
4930       Elm_Win_Indicator_Mode mode)
4931 {
4932    ELM_WIN_CHECK(obj);
4933    eo_do(obj, elm_obj_win_indicator_mode_set(mode));
4934 }
4935
4936 static void
4937 _indicator_mode_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4938 {
4939    Elm_Win_Indicator_Mode mode = va_arg(*list, Elm_Win_Indicator_Mode);
4940    Elm_Win_Smart_Data *sd = _pd;
4941
4942    if (mode == sd->indmode) return;
4943 #ifdef HAVE_ELEMENTARY_X
4944    _elm_win_xwindow_get(sd);
4945 #endif
4946    sd->indmode = mode;
4947 #ifdef HAVE_ELEMENTARY_X
4948    if (sd->x.xwin)
4949      {
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);
4956      }
4957 #endif
4958    evas_object_smart_callback_call(obj, SIG_INDICATOR_PROP_CHANGED, NULL);
4959 }
4960
4961 EAPI Elm_Win_Indicator_Mode
4962 elm_win_indicator_mode_get(const Evas_Object *obj)
4963 {
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));
4967    return ret;
4968 }
4969
4970 static void
4971 _indicator_mode_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4972 {
4973    Elm_Win_Indicator_Mode *ret = va_arg(*list, Elm_Win_Indicator_Mode *);
4974    Elm_Win_Smart_Data *sd = _pd;
4975    *ret = sd->indmode;
4976 }
4977
4978 EAPI void
4979 elm_win_indicator_opacity_set(Evas_Object *obj,
4980                               Elm_Win_Indicator_Opacity_Mode mode)
4981 {
4982    ELM_WIN_CHECK(obj);
4983    eo_do(obj, elm_obj_win_indicator_opacity_set(mode));
4984 }
4985
4986 static void
4987 _indicator_opacity_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
4988 {
4989    Elm_Win_Indicator_Opacity_Mode mode = va_arg(*list, Elm_Win_Indicator_Opacity_Mode);
4990    Elm_Win_Smart_Data *sd = _pd;
4991
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);
4996    if (sd->x.xwin)
4997      {
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);
5007      }
5008 #endif
5009    evas_object_smart_callback_call(obj, SIG_INDICATOR_PROP_CHANGED, NULL);
5010 }
5011
5012 EAPI Elm_Win_Indicator_Opacity_Mode
5013 elm_win_indicator_opacity_get(const Evas_Object *obj)
5014 {
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));
5018    return ret;
5019 }
5020
5021 static void
5022 _indicator_opacity_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5023 {
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;
5027 }
5028
5029 EAPI void
5030 elm_win_screen_position_get(const Evas_Object *obj,
5031                             int *x,
5032                             int *y)
5033 {
5034    ELM_WIN_CHECK(obj);
5035    eo_do((Eo *) obj, elm_obj_win_screen_position_get(x, y));
5036 }
5037
5038 static void
5039 _screen_position_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5040 {
5041    int *x = va_arg(*list, int *);
5042    int *y = va_arg(*list, int *);
5043    Elm_Win_Smart_Data *sd = _pd;
5044
5045    if (x) *x = sd->screen.x;
5046    if (y) *y = sd->screen.y;
5047 }
5048
5049 EAPI Eina_Bool
5050 elm_win_focus_get(const Evas_Object *obj)
5051 {
5052    ELM_WIN_CHECK(obj) EINA_FALSE;
5053    Eina_Bool ret = EINA_FALSE;
5054    eo_do((Eo *) obj, elm_obj_win_focus_get(&ret));
5055    return ret;
5056 }
5057
5058 static void
5059 _focus_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5060 {
5061    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5062    Elm_Win_Smart_Data *sd = _pd;
5063    *ret = ecore_evas_focus_get(sd->ee);
5064 }
5065
5066 EAPI void
5067 elm_win_screen_constrain_set(Evas_Object *obj,
5068                              Eina_Bool constrain)
5069 {
5070    ELM_WIN_CHECK(obj);
5071    eo_do(obj, elm_obj_win_screen_constrain_set(constrain));
5072 }
5073
5074 static void
5075 _screen_constrain_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5076 {
5077    Eina_Bool constrain = va_arg(*list, int);
5078    Elm_Win_Smart_Data *sd = _pd;
5079    sd->constrain = !!constrain;
5080 }
5081
5082 EAPI Eina_Bool
5083 elm_win_screen_constrain_get(Evas_Object *obj)
5084 {
5085    ELM_WIN_CHECK(obj) EINA_FALSE;
5086    Eina_Bool ret = EINA_FALSE;
5087    eo_do(obj, elm_obj_win_screen_constrain_get(&ret));
5088    return ret;
5089 }
5090
5091 static void
5092 _screen_constrain_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5093 {
5094    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5095    Elm_Win_Smart_Data *sd = _pd;
5096    *ret = sd->constrain;
5097 }
5098
5099 EAPI void
5100 elm_win_screen_size_get(const Evas_Object *obj,
5101                         int *x,
5102                         int *y,
5103                         int *w,
5104                         int *h)
5105 {
5106    ELM_WIN_CHECK(obj);
5107    eo_do((Eo *) obj, elm_obj_win_screen_size_get(x, y, w, h));
5108 }
5109
5110 static void
5111 _screen_size_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5112 {
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;
5118
5119    ecore_evas_screen_geometry_get(sd->ee, x, y, w, h);
5120 }
5121
5122 EAPI void
5123 elm_win_screen_dpi_get(const Evas_Object *obj,
5124                        int *xdpi,
5125                        int *ydpi)
5126 {
5127    ELM_WIN_CHECK(obj);
5128    eo_do((Eo *) obj, elm_obj_win_screen_dpi_get(xdpi, ydpi));
5129 }
5130
5131 static void
5132 _screen_dpi_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5133 {
5134    int *xdpi = va_arg(*list, int *);
5135    int *ydpi = va_arg(*list, int *);
5136    Elm_Win_Smart_Data *sd = _pd;
5137
5138    ecore_evas_screen_dpi_get(sd->ee, xdpi, ydpi);
5139 }
5140
5141 EAPI void
5142 elm_win_conformant_set(Evas_Object *obj,
5143                        Eina_Bool conformant)
5144 {
5145    ELM_WIN_CHECK(obj);
5146    eo_do(obj, elm_obj_win_conformant_set(conformant));
5147 }
5148
5149 static void
5150 _conformant_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5151 {
5152    Eina_Bool conformant = va_arg(*list, int);
5153    Elm_Win_Smart_Data *sd = _pd;
5154
5155 #ifdef HAVE_ELEMENTARY_X
5156    _elm_win_xwindow_get(sd);
5157    if (sd->x.xwin)
5158      ecore_x_e_illume_conformant_set(sd->x.xwin, conformant);
5159 #else
5160    (void)conformant;
5161 #endif
5162 }
5163
5164 EAPI Eina_Bool
5165 elm_win_conformant_get(const Evas_Object *obj)
5166 {
5167    ELM_WIN_CHECK(obj) EINA_FALSE;
5168    Eina_Bool ret = EINA_FALSE;
5169    eo_do((Eo *) obj, elm_obj_win_conformant_get(&ret));
5170    return ret;
5171 }
5172
5173 static void
5174 _conformant_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5175 {
5176    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5177    Elm_Win_Smart_Data *sd = _pd;
5178    *ret = EINA_FALSE;
5179
5180 #ifdef HAVE_ELEMENTARY_X
5181    _elm_win_xwindow_get(sd);
5182    if (sd->x.xwin)
5183      *ret = ecore_x_e_illume_conformant_get(sd->x.xwin);
5184 #endif
5185 }
5186
5187 EAPI void
5188 elm_win_quickpanel_set(Evas_Object *obj,
5189                        Eina_Bool quickpanel)
5190 {
5191    ELM_WIN_CHECK(obj);
5192    eo_do(obj, elm_obj_win_quickpanel_set(quickpanel));
5193 }
5194
5195 static void
5196 _quickpanel_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5197 {
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);
5202    if (sd->x.xwin)
5203      {
5204         ecore_x_e_illume_quickpanel_set(sd->x.xwin, quickpanel);
5205         if (quickpanel)
5206           {
5207              Ecore_X_Window_State states[2];
5208
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);
5213           }
5214      }
5215 #else
5216    (void)quickpanel;
5217 #endif
5218 }
5219
5220 EAPI Eina_Bool
5221 elm_win_quickpanel_get(const Evas_Object *obj)
5222 {
5223    ELM_WIN_CHECK(obj) EINA_FALSE;
5224    Eina_Bool ret = EINA_FALSE;
5225    eo_do((Eo *) obj, elm_obj_win_quickpanel_get(&ret));
5226    return ret;
5227 }
5228
5229 static void
5230 _quickpanel_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5231 {
5232    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5233    Elm_Win_Smart_Data *sd = _pd;
5234    *ret = EINA_FALSE;
5235
5236 #ifdef HAVE_ELEMENTARY_X
5237    _elm_win_xwindow_get(sd);
5238    if (sd->x.xwin)
5239      *ret = ecore_x_e_illume_quickpanel_get(sd->x.xwin);
5240 #endif
5241 }
5242
5243 EAPI void
5244 elm_win_quickpanel_priority_major_set(Evas_Object *obj,
5245                                       int priority)
5246 {
5247    ELM_WIN_CHECK(obj);
5248    eo_do(obj, elm_obj_win_quickpanel_priority_major_set(priority));
5249 }
5250
5251 static void
5252 _quickpanel_priority_major_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5253 {
5254    int priority = va_arg(*list, int);
5255    Elm_Win_Smart_Data *sd = _pd;
5256
5257 #ifdef HAVE_ELEMENTARY_X
5258    _elm_win_xwindow_get(sd);
5259    if (sd->x.xwin)
5260      ecore_x_e_illume_quickpanel_priority_major_set(sd->x.xwin, priority);
5261 #else
5262    (void)priority;
5263 #endif
5264 }
5265
5266 EAPI int
5267 elm_win_quickpanel_priority_major_get(const Evas_Object *obj)
5268 {
5269    ELM_WIN_CHECK(obj) - 1;
5270    int ret = - 1;
5271    eo_do((Eo *) obj, elm_obj_win_quickpanel_priority_major_get(&ret));
5272    return ret;
5273 }
5274
5275 static void
5276 _quickpanel_priority_major_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5277 {
5278    int *ret = va_arg(*list, int *);
5279    Elm_Win_Smart_Data *sd = _pd;
5280    *ret = -1;
5281
5282 #ifdef HAVE_ELEMENTARY_X
5283    _elm_win_xwindow_get(sd);
5284    if (sd->x.xwin)
5285      *ret = ecore_x_e_illume_quickpanel_priority_major_get(sd->x.xwin);
5286 #endif
5287 }
5288
5289 EAPI void
5290 elm_win_quickpanel_priority_minor_set(Evas_Object *obj,
5291                                       int priority)
5292 {
5293    ELM_WIN_CHECK(obj);
5294    eo_do(obj, elm_obj_win_quickpanel_priority_minor_set(priority));
5295 }
5296
5297 static void
5298 _quickpanel_priority_minor_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5299 {
5300    int priority = va_arg(*list, int);
5301    Elm_Win_Smart_Data *sd = _pd;
5302
5303 #ifdef HAVE_ELEMENTARY_X
5304    _elm_win_xwindow_get(sd);
5305    if (sd->x.xwin)
5306      ecore_x_e_illume_quickpanel_priority_minor_set(sd->x.xwin, priority);
5307 #else
5308    (void)priority;
5309 #endif
5310 }
5311
5312 EAPI int
5313 elm_win_quickpanel_priority_minor_get(const Evas_Object *obj)
5314 {
5315    ELM_WIN_CHECK(obj) - 1;
5316    int ret = - 1;
5317    eo_do((Eo *) obj, elm_obj_win_quickpanel_priority_minor_get(&ret));
5318    return ret;
5319 }
5320
5321 static void
5322 _quickpanel_priority_minor_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5323 {
5324    int *ret = va_arg(*list, int *);
5325    Elm_Win_Smart_Data *sd = _pd;
5326    *ret = -1;
5327
5328 #ifdef HAVE_ELEMENTARY_X
5329    _elm_win_xwindow_get(sd);
5330    if (sd->x.xwin)
5331      *ret = ecore_x_e_illume_quickpanel_priority_minor_get(sd->x.xwin);
5332 #endif
5333 }
5334
5335 EAPI void
5336 elm_win_quickpanel_zone_set(Evas_Object *obj,
5337                             int zone)
5338 {
5339    ELM_WIN_CHECK(obj);
5340    eo_do(obj, elm_obj_win_quickpanel_zone_set(zone));
5341 }
5342
5343 static void
5344 _quickpanel_zone_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5345 {
5346    int zone = va_arg(*list, int);
5347    Elm_Win_Smart_Data *sd = _pd;
5348
5349 #ifdef HAVE_ELEMENTARY_X
5350    _elm_win_xwindow_get(sd);
5351    if (sd->x.xwin)
5352      ecore_x_e_illume_quickpanel_zone_set(sd->x.xwin, zone);
5353 #else
5354    (void)zone;
5355 #endif
5356 }
5357
5358 EAPI int
5359 elm_win_quickpanel_zone_get(const Evas_Object *obj)
5360 {
5361    ELM_WIN_CHECK(obj) 0;
5362    int ret = 0;
5363    eo_do((Eo *) obj, elm_obj_win_quickpanel_zone_get(&ret));
5364    return ret;
5365 }
5366
5367 static void
5368 _quickpanel_zone_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5369 {
5370    int *ret = va_arg(*list, int *);
5371    Elm_Win_Smart_Data *sd = _pd;
5372    *ret = 0;
5373
5374 #ifdef HAVE_ELEMENTARY_X
5375    _elm_win_xwindow_get(sd);
5376    if (sd->x.xwin)
5377      *ret = ecore_x_e_illume_quickpanel_zone_get(sd->x.xwin);
5378 #endif
5379 }
5380
5381 EAPI void
5382 elm_win_prop_focus_skip_set(Evas_Object *obj,
5383                             Eina_Bool skip)
5384 {
5385    ELM_WIN_CHECK(obj);
5386    eo_do(obj, elm_obj_win_prop_focus_skip_set(skip));
5387 }
5388
5389 static void
5390 _prop_focus_skip_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5391 {
5392    Eina_Bool skip = va_arg(*list, int);
5393    Elm_Win_Smart_Data *sd = _pd;
5394
5395    sd->skip_focus = skip;
5396    TRAP(sd, focus_skip_set, skip);
5397 }
5398
5399 EAPI void
5400 elm_win_illume_command_send(Evas_Object *obj,
5401                             Elm_Illume_Command command,
5402                             void *params)
5403 {
5404    ELM_WIN_CHECK(obj);
5405    eo_do(obj, elm_obj_win_illume_command_send(command, params));
5406 }
5407
5408 static void
5409 _illume_command_send(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5410 {
5411    Elm_Illume_Command command = va_arg(*list, Elm_Illume_Command);
5412    void *params = va_arg(*list, void *);
5413    (void) params;
5414    Elm_Win_Smart_Data *sd = _pd;
5415
5416 #ifdef HAVE_ELEMENTARY_X
5417    _elm_win_xwindow_get(sd);
5418    if (sd->x.xwin)
5419      {
5420         switch (command)
5421           {
5422            case ELM_ILLUME_COMMAND_FOCUS_BACK:
5423              ecore_x_e_illume_focus_back_send(sd->x.xwin);
5424              break;
5425
5426            case ELM_ILLUME_COMMAND_FOCUS_FORWARD:
5427              ecore_x_e_illume_focus_forward_send(sd->x.xwin);
5428              break;
5429
5430            case ELM_ILLUME_COMMAND_FOCUS_HOME:
5431              ecore_x_e_illume_focus_home_send(sd->x.xwin);
5432              break;
5433
5434            case ELM_ILLUME_COMMAND_CLOSE:
5435              ecore_x_e_illume_close_send(sd->x.xwin);
5436              break;
5437
5438            default:
5439              break;
5440           }
5441      }
5442 #else
5443    (void)command;
5444 #endif
5445 }
5446
5447 EAPI Evas_Object *
5448 elm_win_inlined_image_object_get(Evas_Object *obj)
5449 {
5450    ELM_WIN_CHECK(obj) NULL;
5451    Evas_Object *ret = NULL;
5452    eo_do(obj, elm_obj_win_inlined_image_object_get(&ret));
5453    return ret;
5454 }
5455
5456 static void
5457 _inlined_image_object_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5458 {
5459    Evas_Object **ret = va_arg(*list, Evas_Object **);
5460    Elm_Win_Smart_Data *sd = _pd;
5461    *ret = sd->img_obj;
5462 }
5463
5464 EAPI void
5465 elm_win_focus_highlight_enabled_set(Evas_Object *obj,
5466                                     Eina_Bool enabled)
5467 {
5468    ELM_WIN_CHECK(obj);
5469    eo_do(obj, elm_obj_win_focus_highlight_enabled_set(enabled));
5470 }
5471
5472 static void
5473 _focus_highlight_enabled_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5474 {
5475    Eina_Bool enabled = va_arg(*list, int);
5476    Elm_Win_Smart_Data *sd = _pd;
5477
5478    enabled = !!enabled;
5479    if (sd->focus_highlight.enabled == enabled)
5480      return;
5481
5482    sd->focus_highlight.enabled = enabled;
5483
5484    if (sd->focus_highlight.enabled)
5485      _elm_win_focus_highlight_init(sd);
5486    else
5487      _elm_win_focus_highlight_shutdown(sd);
5488 }
5489
5490 EAPI Eina_Bool
5491 elm_win_focus_highlight_enabled_get(const Evas_Object *obj)
5492 {
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));
5496    return ret;
5497 }
5498
5499 static void
5500 _focus_highlight_enabled_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5501 {
5502    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5503    Elm_Win_Smart_Data *sd = _pd;
5504    *ret = sd->focus_highlight.enabled;
5505 }
5506
5507 EAPI void
5508 elm_win_focus_highlight_style_set(Evas_Object *obj,
5509                                   const char *style)
5510 {
5511    ELM_WIN_CHECK(obj);
5512    eo_do(obj, elm_obj_win_focus_highlight_style_set(style));
5513 }
5514
5515 static void
5516 _elm_win_smart_theme(Eo *obj EINA_UNUSED, void *_pd, va_list *list EINA_UNUSED)
5517 {
5518    Elm_Win_Smart_Data *sd = _pd;
5519    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5520    Eina_Bool int_ret = EINA_FALSE;
5521
5522    if (ret) *ret = EINA_TRUE;
5523
5524    eo_do_super(obj, MY_CLASS, elm_wdg_theme_apply(&int_ret));
5525    if (!int_ret) return;
5526
5527    sd->focus_highlight.theme_changed = EINA_TRUE;
5528    _elm_win_focus_highlight_reconfigure_job_start(sd);
5529
5530    if (ret) *ret = EINA_TRUE;
5531 }
5532
5533 static void
5534 _focus_highlight_style_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5535 {
5536    const char *style = va_arg(*list, const char *);
5537    Elm_Win_Smart_Data *sd = _pd;
5538
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);
5542 }
5543
5544 EAPI const char *
5545 elm_win_focus_highlight_style_get(const Evas_Object *obj)
5546 {
5547    ELM_WIN_CHECK(obj) NULL;
5548    const char *ret = NULL;
5549    eo_do((Eo *) obj, elm_obj_win_focus_highlight_style_get(&ret));
5550    return ret;
5551 }
5552
5553 static void
5554 _focus_highlight_style_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5555 {
5556    const char **ret = va_arg(*list, const char **);
5557    Elm_Win_Smart_Data *sd = _pd;
5558    *ret = sd->focus_highlight.style;
5559 }
5560
5561 EAPI void
5562 elm_win_focus_highlight_animate_set(Evas_Object *obj,
5563                                     Eina_Bool animate)
5564 {
5565    ELM_WIN_CHECK(obj);
5566    eo_do(obj, elm_obj_win_focus_highlight_animate_set(animate));
5567 }
5568
5569 static void
5570 _focus_highlight_animate_set(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5571 {
5572    Eina_Bool animate = va_arg(*list, int);
5573    Elm_Win_Smart_Data *sd = _pd;
5574
5575    animate = !!animate;
5576    if (sd->focus_highlight.animate == animate)
5577      return;
5578
5579    sd->focus_highlight.animate = animate;
5580    sd->focus_highlight.theme_changed = EINA_TRUE;
5581    _elm_win_focus_highlight_reconfigure_job_start(sd);
5582 }
5583
5584 EAPI Eina_Bool
5585 elm_win_focus_highlight_animate_get(const Evas_Object *obj)
5586 {
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));
5590    return ret;
5591 }
5592
5593 static void
5594 _focus_highlight_animate_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5595 {
5596    Eina_Bool *ret = va_arg(*list, Eina_Bool *);
5597    Elm_Win_Smart_Data *sd = _pd;
5598    *ret = sd->focus_highlight.animate;
5599 }
5600
5601 EAPI Eina_Bool
5602 elm_win_socket_listen(Evas_Object *obj,
5603                       const char *svcname,
5604                       int svcnum,
5605                       Eina_Bool svcsys)
5606 {
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));
5610    return ret;
5611 }
5612
5613 static void
5614 _socket_listen(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5615 {
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;
5621    *ret = EINA_FALSE;
5622
5623    if (!sd->ee) return;
5624
5625    if (!ecore_evas_extn_socket_listen(sd->ee, svcname, svcnum, svcsys))
5626      return;
5627
5628    *ret = EINA_TRUE;
5629 }
5630
5631 /* windowing specific calls - shall we do this differently? */
5632
5633 EAPI Ecore_X_Window
5634 elm_win_xwindow_get(const Evas_Object *obj)
5635 {
5636    if (!obj) return 0;
5637
5638    if (!evas_object_smart_type_check_ptr(obj, MY_CLASS_NAME_LEGACY))
5639      {
5640         Ecore_Evas *ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
5641         return _elm_ee_xwin_get(ee);
5642      }
5643
5644    ELM_WIN_CHECK(obj) 0;
5645    Ecore_X_Window ret = 0;
5646    eo_do((Eo *) obj, elm_obj_win_xwindow_get(&ret));
5647    return ret;
5648 }
5649
5650 static void
5651 _xwindow_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5652 {
5653    Ecore_X_Window *ret = va_arg(*list, Ecore_X_Window *);
5654    Elm_Win_Smart_Data *sd = _pd;
5655
5656 #ifdef HAVE_ELEMENTARY_X
5657    if (sd->x.xwin)
5658      {
5659         *ret = sd->x.xwin;
5660         return;
5661      }
5662    if (sd->parent)
5663      {
5664         *ret = elm_win_xwindow_get(sd->parent);
5665         return;
5666      }
5667 #endif
5668    *ret = 0;
5669 }
5670
5671 EAPI Ecore_Wl_Window *
5672 elm_win_wl_window_get(const Evas_Object *obj)
5673 {
5674    if (!obj) return NULL;
5675
5676    if ((!ENGINE_COMPARE(ELM_WAYLAND_SHM)) &&
5677        (!ENGINE_COMPARE(ELM_WAYLAND_EGL)))
5678      return NULL;
5679
5680    if (!evas_object_smart_type_check_ptr(obj, MY_CLASS_NAME_LEGACY))
5681      {
5682         Ecore_Evas *ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
5683         return _elm_ee_wlwin_get(ee);
5684      }
5685
5686    ELM_WIN_CHECK(obj) NULL;
5687    Ecore_Wl_Window *ret = NULL;
5688    eo_do((Eo *) obj, elm_obj_win_wl_window_get(&ret));
5689    return ret;
5690 }
5691
5692 static void
5693 _wl_window_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5694 {
5695    Ecore_Wl_Window **ret = va_arg(*list, Ecore_Wl_Window **);
5696 #if HAVE_ELEMENTARY_WAYLAND
5697    Elm_Win_Smart_Data *sd = _pd;
5698    if (sd->wl.win)
5699      {
5700         *ret = sd->wl.win;
5701         return;
5702      }
5703    if (sd->parent)
5704      {
5705         *ret = elm_win_wl_window_get(sd->parent);
5706         return;
5707      }
5708 #else
5709    (void)_pd;
5710 #endif
5711    *ret = NULL;
5712 }
5713
5714 EAPI Eina_Bool
5715 elm_win_trap_set(const Elm_Win_Trap *t)
5716 {
5717    DBG("old %p, new %p", trap, t);
5718
5719    if ((t) && (t->version != ELM_WIN_TRAP_VERSION))
5720      {
5721         CRI("trying to set a trap version %lu while %lu was expected!",
5722                  t->version, ELM_WIN_TRAP_VERSION);
5723         return EINA_FALSE;
5724      }
5725
5726    trap = t;
5727    return EINA_TRUE;
5728 }
5729
5730 EAPI void
5731 elm_win_floating_mode_set(Evas_Object *obj, Eina_Bool floating)
5732 {
5733    ELM_WIN_CHECK(obj);
5734    ELM_WIN_DATA_GET_OR_RETURN(obj, sd);
5735
5736    floating = !!floating;
5737    if (floating == sd->floating) return;
5738    sd->floating = floating;
5739 #ifdef HAVE_ELEMENTARY_X
5740    _elm_win_xwindow_get(sd);
5741    if (sd->x.xwin)
5742      {
5743         if (sd->floating)
5744           ecore_x_e_illume_window_state_set
5745              (sd->x.xwin, ECORE_X_ILLUME_WINDOW_STATE_FLOATING);
5746         else
5747           ecore_x_e_illume_window_state_set
5748              (sd->x.xwin, ECORE_X_ILLUME_WINDOW_STATE_NORMAL);
5749      }
5750 #endif
5751 }
5752
5753 EAPI Eina_Bool
5754 elm_win_floating_mode_get(const Evas_Object *obj)
5755 {
5756    ELM_WIN_CHECK(obj) EINA_FALSE;
5757    ELM_WIN_DATA_GET_OR_RETURN_VAL(obj, sd, EINA_FALSE);
5758
5759    return sd->floating;
5760 }
5761
5762 static void
5763 _window_id_get(Eo *obj EINA_UNUSED, void *_pd, va_list *list)
5764 {
5765    Ecore_Window *ret = va_arg(*list, Ecore_Window *);
5766    Elm_Win_Smart_Data *sd = _pd;
5767
5768    if ((ENGINE_COMPARE(ELM_WAYLAND_SHM)) || (ENGINE_COMPARE(ELM_WAYLAND_EGL)))
5769      {
5770 #if HAVE_ELEMENTARY_WAYLAND
5771         if (sd->wl.win)
5772           {
5773              *ret = (Ecore_Window)ecore_wl_window_surface_id_get(sd->wl.win);
5774              return;
5775           }
5776         if (sd->parent)
5777           {
5778              Ecore_Wl_Window *parent;
5779
5780              parent = elm_win_wl_window_get(sd->parent);
5781              if (parent) *ret = (Ecore_Window)ecore_wl_window_surface_id_get(parent);
5782              return;
5783           }
5784 #endif
5785      }
5786    else
5787      {
5788 #ifdef HAVE_ELEMENTARY_X
5789         _elm_win_xwindow_get(sd);
5790         if (sd->x.xwin)
5791           {
5792              *ret = (Ecore_Window)sd->x.xwin;
5793              return;
5794           }
5795         if (sd->parent)
5796           {
5797              *ret = (Ecore_Window)elm_win_xwindow_get(sd->parent);
5798              return;
5799           }
5800 #endif
5801      }
5802
5803    *ret = 0;
5804 }
5805
5806 EAPI Ecore_Window
5807 elm_win_window_id_get(const Evas_Object *obj)
5808 {
5809    if (!obj) return 0;
5810
5811    if (!evas_object_smart_type_check_ptr(obj, MY_CLASS_NAME_LEGACY))
5812      {
5813         Ecore_Evas *ee = ecore_evas_ecore_evas_get(evas_object_evas_get(obj));
5814         return ecore_evas_window_get(ee);
5815      }
5816
5817    ELM_WIN_CHECK(obj) 0;
5818    Ecore_Window ret = 0;
5819    eo_do((Eo *) obj, elm_obj_win_window_id_get(&ret));
5820    return ret;
5821 }
5822
5823 static void
5824 _class_constructor(Eo_Class *klass)
5825 {
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),
5834
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),
5842
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),
5946
5947         EO_OP_FUNC_SENTINEL
5948    };
5949
5950    eo_class_funcs_set(klass, func_desc);
5951
5952    evas_smart_legacy_type_register(MY_CLASS_NAME_LEGACY, klass);
5953 }
5954
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
6060 };
6061
6062 static const Eo_Class_Description class_desc = {
6063      EO_VERSION,
6064      MY_CLASS_NAME,
6065      EO_CLASS_TYPE_REGULAR,
6066      EO_CLASS_DESCRIPTION_OPS(&ELM_OBJ_WIN_BASE_ID, op_desc, ELM_OBJ_WIN_SUB_ID_LAST),
6067      NULL,
6068      sizeof(Elm_Win_Smart_Data),
6069      _class_constructor,
6070      NULL
6071 };
6072
6073 EO_DEFINE_CLASS(elm_obj_win_class_get, &class_desc, ELM_OBJ_WIDGET_CLASS, NULL);