3 EAPI Ecore_X_Atom ATM__QTOPIA_SOFT_MENU = 0;
4 EAPI Ecore_X_Atom ATM__QTOPIA_SOFT_MENUS = 0;
5 EAPI Ecore_X_Atom ATM_GNOME_SM_PROXY = 0;
6 EAPI Ecore_X_Atom ATM_ENLIGHTENMENT_COMMS = 0;
7 EAPI Ecore_X_Atom ATM_ENLIGHTENMENT_VERSION = 0;
8 EAPI Ecore_X_Atom ATM_ENLIGHTENMENT_SCALE = 0;
13 Ecore_X_Window *roots = NULL;
15 const char *atom_names[] = {
19 "ENLIGHTENMENT_COMMS",
20 "ENLIGHTENMENT_VERSION",
23 Ecore_X_Atom atoms[6];
25 ecore_x_atoms_get(atom_names, 6, atoms);
26 ATM__QTOPIA_SOFT_MENU = atoms[0];
27 ATM__QTOPIA_SOFT_MENUS = atoms[1];
28 ATM_GNOME_SM_PROXY = atoms[2];
29 ATM_ENLIGHTENMENT_COMMS = atoms[3];
30 ATM_ENLIGHTENMENT_VERSION = atoms[4];
31 ATM_ENLIGHTENMENT_SCALE = atoms[5];
33 roots = ecore_x_window_root_list(&num);
36 Ecore_X_Atom supported[41];
40 /* Set what hints we support */
41 /* Root Window Properties (and Related Messages) */
42 supported[supported_num++] = ECORE_X_ATOM_NET_CLIENT_LIST;
43 supported[supported_num++] = ECORE_X_ATOM_NET_CLIENT_LIST_STACKING;
44 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_NUMBER_OF_DESKTOPS, 1);*/
45 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_DESKTOP_GEOMETRY, 1);*/
46 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_DESKTOP_VIEWPORT, 1);*/
47 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_CURRENT_DESKTOP, 1);*/
48 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_DESKTOP_NAMES, 1);*/
49 supported[supported_num++] = ECORE_X_ATOM_NET_ACTIVE_WINDOW;
50 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WORKAREA, 1);*/
51 supported[supported_num++] = ECORE_X_ATOM_NET_SUPPORTING_WM_CHECK;
52 supported[supported_num++] = ECORE_X_ATOM_NET_VIRTUAL_ROOTS;
53 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_DESKTOP_LAYOUT, 1);*/
54 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_SHOWING_DESKTOP, 1);*/
56 /* Other Root Window Messages */
57 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_CLOSE_WINDOW, 1);*/
58 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_MOVERESIZE_WINDOW, 1);*/
59 supported[supported_num++] = ECORE_X_ATOM_NET_WM_MOVERESIZE;
60 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_RESTACK_WINDOW, 1);*/
61 supported[supported_num++] = ECORE_X_ATOM_NET_REQUEST_FRAME_EXTENTS;
63 /* Application Window Properties */
64 supported[supported_num++] = ECORE_X_ATOM_NET_WM_NAME;
65 supported[supported_num++] = ECORE_X_ATOM_NET_WM_VISIBLE_NAME;
66 supported[supported_num++] = ECORE_X_ATOM_NET_WM_ICON_NAME;
67 supported[supported_num++] = ECORE_X_ATOM_NET_WM_VISIBLE_ICON_NAME;
68 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_DESKTOP, 1);*/
69 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE;
70 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_DESKTOP;
71 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_DOCK;
72 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_TOOLBAR;
73 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_MENU;
74 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_UTILITY;
75 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_SPLASH;
76 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_DIALOG;
77 supported[supported_num++] = ECORE_X_ATOM_NET_WM_WINDOW_TYPE_NORMAL;
78 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE;
79 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_MODAL;
80 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_STICKY;
81 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_MAXIMIZED_VERT;
82 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_MAXIMIZED_HORZ;
83 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_SHADED;
84 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_SKIP_TASKBAR;
85 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_SKIP_PAGER;
86 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_HIDDEN;
87 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_FULLSCREEN;
88 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_ABOVE;
89 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STATE_BELOW;
90 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_STATE_DEMANDS_ATTENTION, 1);*/
91 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ALLOWED_ACTIONS, 1);*/
92 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_MOVE, 1);*/
93 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_RESIZE, 1);*/
94 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_MINIMIZE, 1);*/
95 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_SHADE, 1);*/
96 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_STICK, 1);*/
97 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_MAXIMIZE_HORZ, 1);*/
98 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_MAXIMIZE_VERT, 1);*/
99 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_FULLSCREEN, 1);*/
100 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_CHANGE_DESKTOP, 1);*/
101 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ACTION_CLOSE, 1);*/
102 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STRUT;
103 supported[supported_num++] = ECORE_X_ATOM_NET_WM_STRUT_PARTIAL;
104 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_ICON_GEOMETRY, 1);*/
105 supported[supported_num++] = ECORE_X_ATOM_NET_WM_ICON;
106 supported[supported_num++] = ECORE_X_ATOM_NET_WM_PID;
107 /*ecore_x_netwm_supported(roots[supported_num], ECORE_X_ATOM_NET_WM_HANDLED_ICONS, 1);*/
108 supported[supported_num++] = ECORE_X_ATOM_NET_WM_USER_TIME;
109 supported[supported_num++] = ECORE_X_ATOM_NET_FRAME_EXTENTS;
110 supported[supported_num++] = ECORE_X_ATOM_NET_WM_PING;
111 supported[supported_num++] = ECORE_X_ATOM_NET_WM_SYNC_REQUEST;
112 supported[supported_num++] = ECORE_X_ATOM_NET_WM_SYNC_REQUEST_COUNTER;
114 for (i = 0; i < num; i++)
116 Ecore_X_Window win, twin;
121 /* check for previous netwm wm and wait for it to die */
122 ts = ecore_time_get();
123 nwins = ecore_x_window_prop_window_get(roots[i],
124 ECORE_X_ATOM_NET_SUPPORTING_WM_CHECK,
130 nwins = ecore_x_window_prop_window_get(win,
131 ECORE_X_ATOM_NET_SUPPORTING_WM_CHECK,
133 if (nwins < 1) break;
134 if (twin != win) break;
135 if (ecore_x_netwm_name_get(win, &name))
139 if (strcmp(name, "Enlightenment"))
148 if ((ecore_time_get() - ts) > 2.0)
150 e_error_message_show(_("A previous instance of Enlightenment is still active\n"
151 "on this screen. Aborting startup.\n"));
157 /* TODO: Remember this window and close it on shutdown */
158 win = ecore_x_window_new(roots[i], -200, -200, 5, 5);
160 * I don't FUCKING believe it. if we PRETEND we are Kwin - java is happy.
161 * why? it expects a double reparenting wm then. java insists on finding this
162 * out when it should be irrelevant! stupid code! I can't believe the time we
163 * just wasted hunting a bug that wasn't and that is due to sheer stupid
164 * coding (in java's awt layer that swing also uses).
166 /* Now for more stupidity... Openoffice.org will change its look and feel
167 * depending on what wm it thinks there is... so if we pretend to be Kwin...
168 * it tries to use kde preferences, if found.
170 /* I have disabled this now by pretending to be E16 with e16 comms. this
171 * means java plays nice and uses our FRAME property.. but we had to do other
172 * evil stuff as java EXPECTS all this at REPARENT time... i've deferred
173 * reparenting... i hate java!
175 /* ecore_x_netwm_wm_identify(roots[i], win, "KWin");*/
176 ecore_x_netwm_wm_identify(roots[i], win, "Enlightenment");
177 /* this makes openoffice.org read gtk settings so it doesn't look like shit */
178 e_hints_openoffice_gnome_fake(roots[i]);
180 ecore_x_netwm_supported_set(roots[i], supported, supported_num);
182 /* fake mwm, this might crash some ol' motif apps, if
183 they still exist, but at least it makes borderless
184 feature of Eterm and urxvt work... */
185 ecore_x_atom_get("_MOTIF_WM_INFO");
192 * This is here so we don't have to pretend to be Kwin anymore - we pretend
193 * to do old e16 style ipc. in fact we just ignore it... but set up the
197 e_hints_e16_comms_pretend(E_Manager *man)
202 win = ecore_x_window_input_new(man->root, -100, -100, 1, 1);
204 /* to help detect this is NOT e16 */
205 snprintf(buf, sizeof(buf), "Enlightenment %s", VERSION);
206 ecore_x_window_prop_property_set(win, ATM_ENLIGHTENMENT_VERSION, ECORE_X_ATOM_STRING, 8, buf, strlen(buf));
207 ecore_x_window_prop_property_set(man->root, ATM_ENLIGHTENMENT_VERSION, ECORE_X_ATOM_STRING, 8, buf, strlen(buf));
209 snprintf(buf, sizeof(buf), "WINID %8x", (int)win);
210 ecore_x_window_prop_property_set(win, ATM_ENLIGHTENMENT_COMMS, ECORE_X_ATOM_STRING, 8, buf, 14);
212 ecore_x_window_prop_property_set(man->root, ATM_ENLIGHTENMENT_COMMS, ECORE_X_ATOM_STRING, 8, buf, 14);
216 e_hints_manager_init(E_Manager *man)
218 /* Set desktop count, desktop names and workarea */
220 unsigned int *areas = NULL;
223 Ecore_X_Window *vroots = NULL;
224 /* FIXME: Desktop names not yet implemented */
227 e_hints_e16_comms_pretend(man);
229 num = eina_list_count(man->containers);
231 vroots = calloc(num, sizeof(Ecore_X_Window));
234 /* names = calloc(num, sizeof(char *));*/
236 areas = calloc(4 * num, sizeof(unsigned int));
243 EINA_LIST_FOREACH(man->containers, cl, c)
246 areas[4 * i + 1] = c->y;
247 areas[4 * i + 2] = c->w;
248 areas[4 * i + 3] = c->h;
249 vroots[i++] = c->win;
253 ecore_x_netwm_desk_count_set(man->root, num);
255 if (e_config->use_virtual_roots)
257 ecore_x_netwm_desk_roots_set(man->root, vroots, num);
260 /* No need for workarea without desktops */
261 ecore_x_netwm_desk_workareas_set(man->root, num, areas);
268 /* FIXME, this should set the list in map order, not stack order */
270 e_hints_client_list_set(void)
272 Eina_List *ml = NULL, *cl = NULL;
273 unsigned int i = 0, num = 0;
278 Ecore_X_Window *clients = NULL;
280 /* Get client count by adding client lists on all containers */
281 EINA_LIST_FOREACH(e_manager_list(), ml, m)
283 EINA_LIST_FOREACH(m->containers, cl, c)
285 num += e_container_borders_count(c);
289 clients = calloc(num, sizeof(Ecore_X_Window));
293 /* Fetch window IDs and add to array */
296 EINA_LIST_FOREACH(e_manager_list(), ml, m)
299 EINA_LIST_FOREACH(m->containers, cl, c)
301 bl = e_container_border_list_first(c);
302 while ((b = e_container_border_list_next(bl)))
303 clients[i++] = b->client.win;
304 e_container_border_list_free(bl);
308 ecore_x_netwm_client_list_stacking_set(m->root, clients, i);
309 ecore_x_netwm_client_list_set(m->root, clients, i);
313 ecore_x_netwm_client_list_set(m->root, NULL, 0);
314 ecore_x_netwm_client_list_stacking_set(m->root, NULL, 0);
320 EINA_LIST_FOREACH(e_manager_list(), ml, m)
322 ecore_x_netwm_client_list_set(m->root, NULL, 0);
323 ecore_x_netwm_client_list_stacking_set(m->root, NULL, 0);
329 /* Client list is already in stacking order, so this function is nearly
330 * identical to the previous one */
332 e_hints_client_stacking_set(void)
334 Eina_List *ml = NULL, *cl = NULL;
335 unsigned int i = 0, num = 0;
340 Ecore_X_Window *clients = NULL;
342 /* Get client count */
343 EINA_LIST_FOREACH(e_manager_list(), ml, m)
345 EINA_LIST_FOREACH(m->containers, cl, c)
347 num += e_container_borders_count(c);
353 clients = calloc(num, sizeof(Ecore_X_Window));
354 if (!clients) return;
356 EINA_LIST_FOREACH(e_manager_list(), ml, m)
358 EINA_LIST_FOREACH(m->containers, cl, c)
360 bl = e_container_border_list_first(c);
361 while ((b = e_container_border_list_next(bl)))
365 e_error_message_show("e_hints.c: e_hints_client_stacking_set()\n"
367 "Window list size greater than window count.\n"
368 "This is really bad.\n"
369 "Please report this.\n");
372 clients[i++] = b->win;
374 e_container_border_list_free(bl);
379 e_error_message_show("e_hints.c: e_hints_client_stacking_set()\n"
381 "Window list size less than window count.\n"
382 "This is strange, but not harmful.\n"
383 "Please report this.\n");
385 EINA_LIST_FOREACH(e_manager_list(), ml, m)
387 ecore_x_netwm_client_list_stacking_set(m->root, clients, num);
393 EINA_LIST_FOREACH(e_manager_list(), ml, m)
395 ecore_x_netwm_client_list_stacking_set(m->root, NULL, 0);
401 e_hints_active_window_set(E_Manager *man,
406 ecore_x_netwm_client_active_set(man->root, bd->client.win);
408 ecore_x_netwm_client_active_set(man->root, 0);
412 e_hints_window_init(E_Border *bd)
414 E_Remember *rem = NULL;
419 if (bd->client.icccm.state == ECORE_X_WINDOW_STATE_HINT_NONE)
421 if (bd->client.netwm.state.hidden)
422 bd->client.icccm.state = ECORE_X_WINDOW_STATE_HINT_ICONIC;
424 bd->client.icccm.state = ECORE_X_WINDOW_STATE_HINT_NORMAL;
427 if ((rem) && (rem->prop.layer))
429 bd->layer = rem->prop.layer;
430 e_border_layer_set(bd, bd->layer);
434 if (!bd->lock_client_stacking)
436 if (bd->client.netwm.type == ECORE_X_WINDOW_TYPE_DESKTOP)
437 e_border_layer_set(bd, 0);
438 else if (bd->client.netwm.state.stacking == E_STACKING_BELOW)
439 e_border_layer_set(bd, 50);
440 else if (bd->client.netwm.state.stacking == E_STACKING_ABOVE)
441 e_border_layer_set(bd, 150);
442 else if (bd->client.netwm.type == ECORE_X_WINDOW_TYPE_DOCK)
443 e_border_layer_set(bd, 150);
444 #ifdef _F_NOTIFICATION_LAYER_POLICY_
445 else if (bd->client.netwm.type == ECORE_X_WINDOW_TYPE_NOTIFICATION)
446 e_border_layer_set(bd, 240);
449 e_border_layer_set(bd, 100);
455 if ((bd->parent) && (e_config->transient.layer))
456 e_border_layer_set(bd, bd->parent->layer);
459 /* Ignore this, E has incompatible desktop setup */
460 if (ecore_x_netwm_desktop_get(bd->client.win, &bd->client.netwm.desktop))
462 if (bd->client.netwm.desktop == 0xffffffff)
466 else if (bd->client.netwm.desktop < (bd->zone->desk_x_count * bd->zone->desk_y_count))
470 desk = e_desk_at_pos_get(bd->zone, bd->client.netwm.desktop);
472 e_border_desk_set(bd, desk);
476 /* Update netwm desktop with current desktop */
477 e_hints_window_desktop_set(bd);
482 /* Update netwm desktop with current desktop */
483 e_hints_window_desktop_set(bd);
490 if ((ecore_x_netwm_startup_id_get(bd->client.win, &str) && (str)) ||
491 ((bd->client.icccm.client_leader > 0) &&
492 ecore_x_netwm_startup_id_get(bd->client.icccm.client_leader, &str) && (str))
495 if (!strncmp(str, "E_START|", 8))
500 if (id > 0) bd->client.netwm.startup_id = id;
505 /* It's ok not to have fetch flag, should only be set on startup
506 * and not changed. */
507 if (!ecore_x_netwm_pid_get(bd->client.win, &bd->client.netwm.pid))
509 if (bd->client.icccm.client_leader)
511 if (!ecore_x_netwm_pid_get(bd->client.icccm.client_leader, &bd->client.netwm.pid))
512 bd->client.netwm.pid = -1;
515 bd->client.netwm.pid = -1;
518 if (bd->client.netwm.state.sticky)
520 if (!bd->lock_client_sticky)
523 e_hints_window_sticky_set(bd, 0);
525 if (bd->client.netwm.state.shaded)
527 if (!bd->lock_client_shade)
528 e_border_shade(bd, e_hints_window_shade_direction_get(bd));
530 e_hints_window_shaded_set(bd, 0);
532 if ((bd->client.netwm.state.maximized_v) && (bd->client.netwm.state.maximized_h))
534 if (!bd->lock_client_maximize)
536 e_hints_window_size_get(bd);
537 e_border_maximize(bd, e_config->maximize_policy);
540 e_hints_window_maximized_set(bd, 0, 0);
542 else if (bd->client.netwm.state.maximized_h)
544 if (!bd->lock_client_maximize)
546 e_hints_window_size_get(bd);
547 e_border_maximize(bd, (e_config->maximize_policy & E_MAXIMIZE_TYPE) | E_MAXIMIZE_HORIZONTAL);
550 e_hints_window_maximized_set(bd, 0, 0);
552 else if (bd->client.netwm.state.maximized_v)
554 if (!bd->lock_client_maximize)
556 e_hints_window_size_get(bd);
557 e_border_maximize(bd, (e_config->maximize_policy & E_MAXIMIZE_TYPE) | E_MAXIMIZE_VERTICAL);
560 e_hints_window_maximized_set(bd, 0, 0);
562 if (bd->client.netwm.state.fullscreen)
564 if (!bd->lock_client_fullscreen)
566 e_hints_window_size_get(bd);
567 e_border_fullscreen(bd, e_config->fullscreen_policy);
570 e_hints_window_fullscreen_set(bd, 0);
572 if ((bd->client.icccm.state == ECORE_X_WINDOW_STATE_HINT_ICONIC) &&
573 (bd->client.netwm.state.hidden))
575 if (!bd->lock_client_iconify)
576 e_border_iconify(bd);
578 e_hints_window_visible_set(bd);
580 else if ((bd->parent) && (e_config->transient.iconify) && (bd->parent->iconic))
581 e_border_iconify(bd);
582 /* If a window isn't iconic, and is one the current desk,
584 else if (bd->desk == e_desk_current_get(bd->zone))
588 if (bd->client.e.state.centered)
593 /* Update stacking */
594 e_hints_client_list_set();
595 e_hints_client_stacking_set();
599 e_hints_window_state_set(E_Border *bd)
601 Ecore_X_Window_State state[10];
604 if (bd->client.netwm.state.modal)
605 state[num++] = ECORE_X_WINDOW_STATE_MODAL;
606 if (bd->client.netwm.state.sticky)
607 state[num++] = ECORE_X_WINDOW_STATE_STICKY;
608 if (bd->client.netwm.state.maximized_v)
609 state[num++] = ECORE_X_WINDOW_STATE_MAXIMIZED_VERT;
610 if (bd->client.netwm.state.maximized_h)
611 state[num++] = ECORE_X_WINDOW_STATE_MAXIMIZED_HORZ;
612 if (bd->client.netwm.state.shaded)
613 state[num++] = ECORE_X_WINDOW_STATE_SHADED;
614 if (bd->client.netwm.state.skip_taskbar)
615 state[num++] = ECORE_X_WINDOW_STATE_SKIP_TASKBAR;
616 if (bd->client.netwm.state.skip_pager)
617 state[num++] = ECORE_X_WINDOW_STATE_SKIP_PAGER;
618 if (bd->client.netwm.state.hidden)
619 state[num++] = ECORE_X_WINDOW_STATE_HIDDEN;
620 if (bd->client.netwm.state.fullscreen)
621 state[num++] = ECORE_X_WINDOW_STATE_FULLSCREEN;
623 switch (bd->client.netwm.state.stacking)
625 case E_STACKING_ABOVE:
626 state[num++] = ECORE_X_WINDOW_STATE_ABOVE;
629 case E_STACKING_BELOW:
630 state[num++] = ECORE_X_WINDOW_STATE_BELOW;
633 case E_STACKING_NONE:
637 ecore_x_netwm_window_state_set(bd->client.win, state, num);
641 e_hints_allowed_action_set(E_Border *bd)
643 Ecore_X_Action action[10];
646 if (bd->client.netwm.action.move)
647 action[num++] = ECORE_X_ACTION_MOVE;
648 if (bd->client.netwm.action.resize)
649 action[num++] = ECORE_X_ACTION_RESIZE;
650 if (bd->client.netwm.action.minimize)
651 action[num++] = ECORE_X_ACTION_MINIMIZE;
652 if (bd->client.netwm.action.shade)
653 action[num++] = ECORE_X_ACTION_SHADE;
654 if (bd->client.netwm.action.stick)
655 action[num++] = ECORE_X_ACTION_STICK;
656 if (bd->client.netwm.action.maximized_h)
657 action[num++] = ECORE_X_ACTION_MAXIMIZE_HORZ;
658 if (bd->client.netwm.action.maximized_v)
659 action[num++] = ECORE_X_ACTION_MAXIMIZE_VERT;
660 if (bd->client.netwm.action.fullscreen)
661 action[num++] = ECORE_X_ACTION_FULLSCREEN;
662 if (bd->client.netwm.action.change_desktop)
663 action[num++] = ECORE_X_ACTION_CHANGE_DESKTOP;
664 if (bd->client.netwm.action.close)
665 action[num++] = ECORE_X_ACTION_CLOSE;
667 ecore_x_netwm_allowed_action_set(bd->client.win, action, num);
671 e_hints_window_type_set(E_Border *bd)
673 ecore_x_netwm_window_type_set(bd->client.win, bd->client.netwm.type);
677 e_hints_window_type_get(E_Border *bd)
679 Ecore_X_Window_Type *types = NULL;
682 num = ecore_x_netwm_window_types_get(bd->client.win, &types);
683 if (bd->client.netwm.extra_types)
685 free(bd->client.netwm.extra_types);
686 bd->client.netwm.extra_types = NULL;
687 bd->client.netwm.extra_types_num = 0;
690 bd->client.netwm.type = ECORE_X_WINDOW_TYPE_UNKNOWN;
694 bd->client.netwm.type = types[j];
697 (bd->client.netwm.type == ECORE_X_WINDOW_TYPE_UNKNOWN))
700 bd->client.netwm.type = types[j];
704 bd->client.netwm.extra_types =
705 malloc((num - j) * sizeof(Ecore_X_Window_Type));
706 if (bd->client.netwm.extra_types)
708 for (i = j + 1; i < num; i++)
709 bd->client.netwm.extra_types[i - (j + 1)] = types[i];
710 bd->client.netwm.extra_types_num = num - j;
718 e_hints_window_state_update(E_Border *bd,
719 Ecore_X_Window_State state,
720 Ecore_X_Window_State_Action action)
724 case ECORE_X_WINDOW_STATE_ICONIFIED:
725 if (action != ECORE_X_WINDOW_STATE_ACTION_ADD) return;
726 if (bd->client.icccm.state == ECORE_X_WINDOW_STATE_HINT_ICONIC) return;
727 if (bd->lock_client_iconify) return;
728 e_border_iconify(bd);
731 case ECORE_X_WINDOW_STATE_MODAL:
734 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
735 if (bd->client.netwm.state.modal)
737 bd->client.netwm.state.modal = 0;
738 bd->client.netwm.update.state = 1;
743 case ECORE_X_WINDOW_STATE_ACTION_ADD:
744 if (!bd->client.netwm.state.modal)
746 bd->client.netwm.state.modal = 1;
747 bd->client.netwm.update.state = 1;
752 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
753 bd->client.netwm.state.modal = !bd->client.netwm.state.modal;
754 bd->client.netwm.update.state = 1;
760 case ECORE_X_WINDOW_STATE_STICKY:
761 if (bd->lock_client_sticky) return;
764 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
765 e_border_unstick(bd);
768 case ECORE_X_WINDOW_STATE_ACTION_ADD:
772 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
774 e_border_unstick(bd);
781 case ECORE_X_WINDOW_STATE_MAXIMIZED_VERT:
782 if (bd->lock_client_maximize) return;
785 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
786 if (bd->maximized & E_MAXIMIZE_VERTICAL)
787 e_border_unmaximize(bd, E_MAXIMIZE_VERTICAL);
790 case ECORE_X_WINDOW_STATE_ACTION_ADD:
791 if (!(bd->maximized & E_MAXIMIZE_VERTICAL))
792 e_border_maximize(bd, (e_config->maximize_policy & E_MAXIMIZE_TYPE) | E_MAXIMIZE_VERTICAL);
795 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
796 if (bd->maximized & E_MAXIMIZE_VERTICAL)
797 e_border_unmaximize(bd, E_MAXIMIZE_VERTICAL);
799 e_border_maximize(bd, (e_config->maximize_policy & E_MAXIMIZE_TYPE) | E_MAXIMIZE_VERTICAL);
804 case ECORE_X_WINDOW_STATE_MAXIMIZED_HORZ:
805 if (bd->lock_client_maximize) return;
808 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
809 if (bd->maximized & E_MAXIMIZE_HORIZONTAL)
810 e_border_unmaximize(bd, E_MAXIMIZE_HORIZONTAL);
813 case ECORE_X_WINDOW_STATE_ACTION_ADD:
814 if (!(bd->maximized & E_MAXIMIZE_HORIZONTAL))
815 e_border_maximize(bd, (e_config->maximize_policy & E_MAXIMIZE_TYPE) | E_MAXIMIZE_HORIZONTAL);
818 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
819 if (bd->maximized & E_MAXIMIZE_HORIZONTAL)
820 e_border_unmaximize(bd, E_MAXIMIZE_HORIZONTAL);
822 e_border_maximize(bd, (e_config->maximize_policy & E_MAXIMIZE_TYPE) | E_MAXIMIZE_HORIZONTAL);
827 case ECORE_X_WINDOW_STATE_SHADED:
828 if (bd->lock_client_shade) return;
831 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
832 e_border_unshade(bd, e_hints_window_shade_direction_get(bd));
835 case ECORE_X_WINDOW_STATE_ACTION_ADD:
836 e_border_shade(bd, e_hints_window_shade_direction_get(bd));
839 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
841 e_border_unshade(bd, e_hints_window_shade_direction_get(bd));
843 e_border_shade(bd, e_hints_window_shade_direction_get(bd));
848 case ECORE_X_WINDOW_STATE_SKIP_TASKBAR:
851 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
852 if (bd->client.netwm.state.skip_taskbar)
854 bd->client.netwm.state.skip_taskbar = 0;
855 bd->client.netwm.update.state = 1;
860 case ECORE_X_WINDOW_STATE_ACTION_ADD:
861 if (!bd->client.netwm.state.skip_taskbar)
863 bd->client.netwm.state.skip_taskbar = 1;
864 bd->client.netwm.update.state = 1;
869 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
870 bd->client.netwm.state.skip_taskbar = !bd->client.netwm.state.skip_taskbar;
871 bd->client.netwm.update.state = 1;
877 case ECORE_X_WINDOW_STATE_SKIP_PAGER:
880 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
881 if (bd->client.netwm.state.skip_pager)
883 bd->client.netwm.state.skip_pager = 0;
884 bd->client.netwm.update.state = 1;
889 case ECORE_X_WINDOW_STATE_ACTION_ADD:
890 if (!bd->client.netwm.state.skip_pager)
892 bd->client.netwm.state.skip_pager = 1;
893 bd->client.netwm.update.state = 1;
898 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
899 bd->client.netwm.state.skip_pager = !bd->client.netwm.state.skip_pager;
900 bd->client.netwm.update.state = 1;
906 case ECORE_X_WINDOW_STATE_HIDDEN:
910 case ECORE_X_WINDOW_STATE_FULLSCREEN:
911 if (bd->lock_client_fullscreen) return;
914 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
915 e_border_unfullscreen(bd);
918 case ECORE_X_WINDOW_STATE_ACTION_ADD:
919 e_border_fullscreen(bd, e_config->fullscreen_policy);
922 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
924 e_border_unfullscreen(bd);
926 e_border_fullscreen(bd, e_config->fullscreen_policy);
931 case ECORE_X_WINDOW_STATE_ABOVE:
932 if (bd->lock_client_stacking) return;
933 /* FIXME: Should this require that BELOW is set to 0 first, or just
937 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
938 e_border_layer_set(bd, 100);
939 e_hints_window_stacking_set(bd, E_STACKING_NONE);
942 case ECORE_X_WINDOW_STATE_ACTION_ADD:
943 e_hints_window_stacking_set(bd, E_STACKING_ABOVE);
944 e_border_layer_set(bd, 150);
947 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
948 if (bd->layer == 150)
950 e_hints_window_stacking_set(bd, E_STACKING_NONE);
951 e_border_layer_set(bd, 100);
955 e_hints_window_stacking_set(bd, E_STACKING_ABOVE);
956 e_border_layer_set(bd, 150);
962 case ECORE_X_WINDOW_STATE_BELOW:
963 if (bd->lock_client_stacking) return;
964 /* FIXME: Should this require that ABOVE is set to 0 first, or just
968 case ECORE_X_WINDOW_STATE_ACTION_REMOVE:
969 e_hints_window_stacking_set(bd, E_STACKING_NONE);
970 e_border_layer_set(bd, 100);
973 case ECORE_X_WINDOW_STATE_ACTION_ADD:
974 e_hints_window_stacking_set(bd, E_STACKING_BELOW);
975 e_border_layer_set(bd, 50);
978 case ECORE_X_WINDOW_STATE_ACTION_TOGGLE:
981 e_hints_window_stacking_set(bd, E_STACKING_NONE);
982 e_border_layer_set(bd, 100);
986 e_hints_window_stacking_set(bd, E_STACKING_BELOW);
987 e_border_layer_set(bd, 50);
993 case ECORE_X_WINDOW_STATE_DEMANDS_ATTENTION:
997 case ECORE_X_WINDOW_STATE_UNKNOWN:
1004 e_hints_window_state_get(E_Border *bd)
1006 unsigned int i, num;
1007 Ecore_X_Window_State *state;
1009 bd->client.netwm.state.modal = 0;
1010 bd->client.netwm.state.sticky = 0;
1011 bd->client.netwm.state.maximized_v = 0;
1012 bd->client.netwm.state.maximized_h = 0;
1013 bd->client.netwm.state.shaded = 0;
1014 bd->client.netwm.state.skip_taskbar = 0;
1015 bd->client.netwm.state.skip_pager = 0;
1016 bd->client.netwm.state.hidden = 0;
1017 bd->client.netwm.state.fullscreen = 0;
1018 bd->client.netwm.state.stacking = 0;
1020 ecore_x_netwm_window_state_get(bd->client.win, &state, &num);
1023 for (i = 0; i < num; i++)
1027 case ECORE_X_WINDOW_STATE_ICONIFIED:
1031 case ECORE_X_WINDOW_STATE_MODAL:
1032 bd->client.netwm.state.modal = 1;
1035 case ECORE_X_WINDOW_STATE_STICKY:
1036 bd->client.netwm.state.sticky = 1;
1039 case ECORE_X_WINDOW_STATE_MAXIMIZED_VERT:
1040 bd->client.netwm.state.maximized_v = 1;
1043 case ECORE_X_WINDOW_STATE_MAXIMIZED_HORZ:
1044 bd->client.netwm.state.maximized_h = 1;
1047 case ECORE_X_WINDOW_STATE_SHADED:
1048 bd->client.netwm.state.shaded = 1;
1051 case ECORE_X_WINDOW_STATE_SKIP_TASKBAR:
1052 bd->client.netwm.state.skip_taskbar = 1;
1055 case ECORE_X_WINDOW_STATE_SKIP_PAGER:
1056 bd->client.netwm.state.skip_pager = 1;
1059 case ECORE_X_WINDOW_STATE_HIDDEN:
1060 bd->client.netwm.state.hidden = 1;
1063 case ECORE_X_WINDOW_STATE_FULLSCREEN:
1064 bd->client.netwm.state.fullscreen = 1;
1067 case ECORE_X_WINDOW_STATE_ABOVE:
1068 bd->client.netwm.state.stacking = E_STACKING_ABOVE;
1071 case ECORE_X_WINDOW_STATE_BELOW:
1072 bd->client.netwm.state.stacking = E_STACKING_BELOW;
1075 case ECORE_X_WINDOW_STATE_DEMANDS_ATTENTION:
1079 case ECORE_X_WINDOW_STATE_UNKNOWN:
1089 e_hints_allowed_action_update(E_Border *bd __UNUSED__,
1090 Ecore_X_Action action)
1094 case ECORE_X_ACTION_MOVE:
1097 case ECORE_X_ACTION_RESIZE:
1100 case ECORE_X_ACTION_MINIMIZE:
1103 case ECORE_X_ACTION_SHADE:
1106 case ECORE_X_ACTION_STICK:
1109 case ECORE_X_ACTION_MAXIMIZE_HORZ:
1112 case ECORE_X_ACTION_MAXIMIZE_VERT:
1115 case ECORE_X_ACTION_FULLSCREEN:
1118 case ECORE_X_ACTION_CHANGE_DESKTOP:
1121 case ECORE_X_ACTION_CLOSE:
1124 case ECORE_X_ACTION_ABOVE:
1127 case ECORE_X_ACTION_BELOW:
1133 e_hints_allowed_action_get(E_Border *bd)
1135 Ecore_X_Action *action;
1139 bd->client.netwm.action.move = 0;
1140 bd->client.netwm.action.resize = 0;
1141 bd->client.netwm.action.minimize = 0;
1142 bd->client.netwm.action.shade = 0;
1143 bd->client.netwm.action.stick = 0;
1144 bd->client.netwm.action.maximized_h = 0;
1145 bd->client.netwm.action.maximized_v = 0;
1146 bd->client.netwm.action.fullscreen = 0;
1147 bd->client.netwm.action.change_desktop = 0;
1148 bd->client.netwm.action.close = 0;
1150 ecore_x_netwm_allowed_action_get(bd->client.win, &action, &num);
1153 for (i = 0; i < num; i++)
1157 case ECORE_X_ACTION_MOVE:
1158 bd->client.netwm.action.move = 1;
1161 case ECORE_X_ACTION_RESIZE:
1162 bd->client.netwm.action.resize = 1;
1165 case ECORE_X_ACTION_MINIMIZE:
1166 bd->client.netwm.action.minimize = 1;
1169 case ECORE_X_ACTION_SHADE:
1170 bd->client.netwm.action.shade = 1;
1173 case ECORE_X_ACTION_STICK:
1174 bd->client.netwm.action.stick = 1;
1177 case ECORE_X_ACTION_MAXIMIZE_HORZ:
1178 bd->client.netwm.action.maximized_h = 1;
1181 case ECORE_X_ACTION_MAXIMIZE_VERT:
1182 bd->client.netwm.action.maximized_v = 1;
1185 case ECORE_X_ACTION_FULLSCREEN:
1186 bd->client.netwm.action.fullscreen = 1;
1189 case ECORE_X_ACTION_CHANGE_DESKTOP:
1190 bd->client.netwm.action.change_desktop = 1;
1193 case ECORE_X_ACTION_CLOSE:
1194 bd->client.netwm.action.close = 1;
1197 case ECORE_X_ACTION_ABOVE:
1200 case ECORE_X_ACTION_BELOW:
1209 e_hints_window_visible_set(E_Border *bd)
1211 if (bd->client.icccm.state != ECORE_X_WINDOW_STATE_HINT_NORMAL)
1213 ecore_x_icccm_state_set(bd->client.win, ECORE_X_WINDOW_STATE_HINT_NORMAL);
1214 bd->client.icccm.state = ECORE_X_WINDOW_STATE_HINT_NORMAL;
1216 if (bd->client.netwm.state.hidden)
1218 bd->client.netwm.update.state = 1;
1219 bd->client.netwm.state.hidden = 0;
1225 e_hints_window_iconic_set(E_Border *bd)
1227 if (bd->client.icccm.state != ECORE_X_WINDOW_STATE_HINT_ICONIC)
1229 ecore_x_icccm_state_set(bd->client.win, ECORE_X_WINDOW_STATE_HINT_ICONIC);
1230 bd->client.icccm.state = ECORE_X_WINDOW_STATE_HINT_ICONIC;
1232 if (!bd->client.netwm.state.hidden)
1234 bd->client.netwm.update.state = 1;
1235 bd->client.netwm.state.hidden = 1;
1241 e_hints_window_hidden_set(E_Border *bd)
1243 if (bd->client.icccm.state != ECORE_X_WINDOW_STATE_HINT_WITHDRAWN)
1245 ecore_x_icccm_state_set(bd->client.win, ECORE_X_WINDOW_STATE_HINT_WITHDRAWN);
1246 bd->client.icccm.state = ECORE_X_WINDOW_STATE_HINT_WITHDRAWN;
1248 if (bd->client.netwm.state.hidden)
1250 bd->client.netwm.update.state = 1;
1251 bd->client.netwm.state.hidden = 0;
1257 e_hints_window_shaded_set(E_Border *bd,
1260 if ((!bd->client.netwm.state.shaded) && (on))
1262 bd->client.netwm.update.state = 1;
1263 bd->client.netwm.state.shaded = 1;
1266 else if ((bd->client.netwm.state.shaded) && (!on))
1268 bd->client.netwm.update.state = 1;
1269 bd->client.netwm.state.shaded = 0;
1275 e_hints_window_shade_direction_set(E_Border *bd,
1278 ecore_x_window_prop_card32_set(bd->client.win, E_ATOM_SHADE_DIRECTION, &dir, 1);
1282 e_hints_window_shade_direction_get(E_Border *bd)
1287 ret = ecore_x_window_prop_card32_get(bd->client.win,
1288 E_ATOM_SHADE_DIRECTION,
1293 return E_DIRECTION_UP;
1297 e_hints_window_size_set(E_Border *bd)
1299 unsigned int sizes[4];
1305 ecore_x_window_prop_card32_set(bd->client.win, E_ATOM_BORDER_SIZE, sizes, 4);
1309 e_hints_window_size_unset(E_Border *bd)
1311 ecore_x_window_prop_property_del(bd->client.win, E_ATOM_BORDER_SIZE);
1315 e_hints_window_size_get(E_Border *bd)
1318 unsigned int sizes[4];
1320 memset(sizes, 0, sizeof(sizes));
1321 ret = ecore_x_window_prop_card32_get(bd->client.win, E_ATOM_BORDER_SIZE,
1335 e_hints_window_maximized_set(E_Border *bd,
1339 if ((horizontal) && (!bd->client.netwm.state.maximized_h))
1341 bd->client.netwm.update.state = 1;
1342 bd->client.netwm.state.maximized_h = 1;
1345 else if ((!horizontal) && (bd->client.netwm.state.maximized_h))
1347 bd->client.netwm.update.state = 1;
1348 bd->client.netwm.state.maximized_h = 0;
1351 if ((vertical) && (!bd->client.netwm.state.maximized_v))
1353 bd->client.netwm.update.state = 1;
1354 bd->client.netwm.state.maximized_v = 1;
1357 else if ((!vertical) && (bd->client.netwm.state.maximized_v))
1359 bd->client.netwm.update.state = 1;
1360 bd->client.netwm.state.maximized_v = 0;
1366 e_hints_window_fullscreen_set(E_Border *bd,
1369 if ((!bd->client.netwm.state.fullscreen) && (on))
1371 bd->client.netwm.update.state = 1;
1372 bd->client.netwm.state.fullscreen = 1;
1375 else if ((bd->client.netwm.state.fullscreen) && (!on))
1377 bd->client.netwm.update.state = 1;
1378 bd->client.netwm.state.fullscreen = 0;
1384 e_hints_window_sticky_set(E_Border *bd,
1387 if ((!bd->client.netwm.state.sticky) && (on))
1389 bd->client.netwm.update.state = 1;
1390 bd->client.netwm.state.sticky = 1;
1393 else if ((bd->client.netwm.state.sticky) && (!on))
1395 bd->client.netwm.update.state = 1;
1396 bd->client.netwm.state.sticky = 0;
1402 e_hints_window_stacking_set(E_Border *bd,
1403 E_Stacking stacking)
1405 if (bd->client.netwm.state.stacking == stacking) return;
1406 bd->client.netwm.update.state = 1;
1407 bd->client.netwm.state.stacking = stacking;
1412 e_hints_window_desktop_set(E_Border *bd)
1414 /* This function is only called when really changing desktop,
1415 * so just set the property and don't care about the roundtrip.
1417 unsigned int deskpos[2];
1419 /* if valgrind complains here it is complaining bd->client.netwm.desktop
1420 * is an uninitialised variable - but it isn't. it can't be. its part of
1421 * a calloc()'d struct and thus has to have been set to 0. hell even
1422 * e_border.c explicitly sets it to 0 on creation of the border object.
1424 deskpos[0] = bd->desk->x;
1425 deskpos[1] = bd->desk->y;
1426 ecore_x_window_prop_card32_set(bd->client.win, E_ATOM_DESK, deskpos, 2);
1429 ecore_x_netwm_desktop_set(bd->client.win, current);
1431 bd->client.netwm.desktop = (bd->desk->y * bd->zone->desk_x_count) + bd->desk->x;
1435 e_hints_window_e_state_get(E_Border *bd)
1437 /* Remember to update the count if we add more states! */
1438 Ecore_X_Atom state[1];
1442 memset(state, 0, sizeof(state));
1444 /* ugly, but avoids possible future overflow if more states are added */
1445 size = (sizeof(state) / sizeof(state[0]));
1448 ecore_x_window_prop_card32_get(bd->client.win, E_ATOM_WINDOW_STATE,
1452 for (i = 0; (i < num) && (i < size); i++)
1454 if (state[i] == E_ATOM_WINDOW_STATE_CENTERED)
1455 bd->client.e.state.centered = 1;
1460 e_hints_window_e_state_set(E_Border *bd __UNUSED__)
1466 e_hints_window_qtopia_soft_menu_get(E_Border *bd)
1470 if (ecore_x_window_prop_card32_get(bd->client.win, ATM__QTOPIA_SOFT_MENU, &val, 1))
1471 bd->client.qtopia.soft_menu = val;
1473 bd->client.qtopia.soft_menu = 0;
1477 e_hints_window_qtopia_soft_menus_get(E_Border *bd)
1481 if (ecore_x_window_prop_card32_get(bd->client.win, ATM__QTOPIA_SOFT_MENUS, &val, 1))
1482 bd->client.qtopia.soft_menus = val;
1484 bd->client.qtopia.soft_menus = 0;
1488 e_hints_window_virtual_keyboard_state_get(E_Border *bd)
1490 bd->client.vkbd.state = ecore_x_e_virtual_keyboard_state_get(bd->client.win);
1494 e_hints_window_virtual_keyboard_get(E_Border *bd)
1496 bd->client.vkbd.vkbd = ecore_x_e_virtual_keyboard_get(bd->client.win);
1500 e_hints_openoffice_gnome_fake(Ecore_X_Window root)
1502 const char *string = "ATM_GNOME_SM_PROXY";
1504 ecore_x_window_prop_property_set(root, ATM_GNOME_SM_PROXY, ECORE_X_ATOM_STRING,
1505 8, (void *)string, strlen(string));
1509 e_hints_openoffice_kde_fake(Ecore_X_Window root)
1511 Ecore_X_Window win2;
1513 win2 = ecore_x_window_new(root, -20, -20, 1, 1);
1514 ecore_x_netwm_wm_identify(root, win2, "KWin");
1518 e_hints_scale_update(void)
1520 Ecore_X_Window *roots = NULL;
1524 roots = ecore_x_window_root_list(&num);
1527 scale = e_scale * 1000;
1528 for (i = 0; i < num; i++)
1529 ecore_x_window_prop_card32_set(roots[i], ATM_ENLIGHTENMENT_SCALE, &scale, 1);