Ecore_Wl2_Window *window;
window = data;
- window->config.serial = serial;
+ window->req_config.serial = serial;
if (!window->pending.configure) return;
_configure_complete(window);
uint32_t *s;
Eina_Bool fs, max;
- if ((!win->config.maximized) && (!win->config.fullscreen))
- win->saved = win->config.geometry;
+ fs = win->req_config.fullscreen;
+ max = win->req_config.maximized;
- fs = win->config.fullscreen;
- max = win->config.maximized;
-
- win->config.minimized = EINA_FALSE;
- win->config.maximized = EINA_FALSE;
- win->config.fullscreen = EINA_FALSE;
- win->config.focused = EINA_FALSE;
- win->config.resizing = EINA_FALSE;
+ win->req_config.minimized = EINA_FALSE;
+ win->req_config.maximized = EINA_FALSE;
+ win->req_config.fullscreen = EINA_FALSE;
+ win->req_config.focused = EINA_FALSE;
+ win->req_config.resizing = EINA_FALSE;
wl_array_for_each(s, states)
{
switch (*s)
{
case ZXDG_TOPLEVEL_V6_STATE_MAXIMIZED:
- win->config.maximized = EINA_TRUE;
+ win->req_config.maximized = EINA_TRUE;
break;
case ZXDG_TOPLEVEL_V6_STATE_FULLSCREEN:
- win->config.fullscreen = EINA_TRUE;
+ win->req_config.fullscreen = EINA_TRUE;
break;
case ZXDG_TOPLEVEL_V6_STATE_RESIZING:
- win->config.resizing = EINA_TRUE;
+ win->req_config.resizing = EINA_TRUE;
break;
case ZXDG_TOPLEVEL_V6_STATE_ACTIVATED:
- win->config.focused = EINA_TRUE;
- win->config.minimized = EINA_FALSE;
+ win->req_config.focused = EINA_TRUE;
+ win->req_config.minimized = EINA_FALSE;
default:
break;
}
}
- if ((win->config.geometry.w == width) &&
- (win->config.geometry.h == height))
+ if ((win->set_config.geometry.w == width) &&
+ (win->set_config.geometry.h == height))
width = height = 0;
- else if ((!width) && (!height) && (!win->config.fullscreen) &&
- (!win->config.maximized) &&
- ((win->config.fullscreen != fs) ||
- (win->config.maximized != max)))
+ else if ((!width) && (!height) && (!win->req_config.fullscreen) &&
+ (!win->req_config.maximized) &&
+ ((win->req_config.fullscreen != fs) ||
+ (win->req_config.maximized != max)))
width = win->saved.w, height = win->saved.h;
- _ecore_wl2_window_configure_send(win, width, height, !!win->config.resizing,
- win->config.fullscreen, win->config.maximized);
+ _ecore_wl2_window_configure_send(win, width, height, !!win->req_config.resizing,
+ win->req_config.fullscreen, win->req_config.maximized);
- if (win->config.focused)
+ if (win->req_config.focused)
_ecore_wl2_window_activate_send(win);
else
_ecore_wl2_window_deactivate_send(win);
pos = zxdg_shell_v6_create_positioner(win->display->wl.zxdg_shell);
if (!pos) return;
- zxdg_positioner_v6_set_anchor_rect(pos, win->config.geometry.x, win->config.geometry.y,
+ zxdg_positioner_v6_set_anchor_rect(pos, win->set_config.geometry.x,
+ win->set_config.geometry.y,
1, 1);
- zxdg_positioner_v6_set_size(pos, win->config.geometry.w, win->config.geometry.h);
+ zxdg_positioner_v6_set_size(pos, win->set_config.geometry.w,
+ win->set_config.geometry.h);
zxdg_positioner_v6_set_anchor(pos, ZXDG_POSITIONER_V6_ANCHOR_TOP |
ZXDG_POSITIONER_V6_ANCHOR_LEFT);
zxdg_positioner_v6_set_gravity(pos, ZXDG_POSITIONER_V6_ANCHOR_BOTTOM |
if (ptop)
zxdg_toplevel_v6_set_parent(window->zxdg_toplevel, ptop);
- if (window->config.maximized)
+ if (window->set_config.maximized)
zxdg_toplevel_v6_set_maximized(window->zxdg_toplevel);
- if (window->config.fullscreen)
+ if (window->set_config.fullscreen)
zxdg_toplevel_v6_set_fullscreen(window->zxdg_toplevel, NULL);
if (window->aspect.set && window->display->wl.efl_hints)
efl_hints_set_aspect(window->display->wl.efl_hints, window->zxdg_toplevel,
window->surface, window->uuid);
if (window->zxdg_surface)
zxdg_surface_v6_set_window_geometry(window->zxdg_surface,
- window->config.geometry.x,
- window->config.geometry.y,
- window->config.geometry.w,
- window->config.geometry.h);
+ window->set_config.geometry.x,
+ window->set_config.geometry.y,
+ window->set_config.geometry.w,
+ window->set_config.geometry.h);
ecore_wl2_window_opaque_region_set(window,
window->opaque.x,
win->parent = parent;
win->id = _win_id++;
- win->config.geometry.x = x;
- win->config.geometry.y = y;
- win->config.geometry.w = w;
- win->config.geometry.h = h;
+ win->set_config.geometry.x = x;
+ win->set_config.geometry.y = y;
+ win->set_config.geometry.w = w;
+ win->set_config.geometry.h = h;
win->opaque.x = x;
win->opaque.y = y;
window->callback = NULL;
}
- window->config.serial = 0;
+ window->set_config.serial = 0;
+ window->req_config.serial = 0;
window->zxdg_configure_ack = NULL;
window->zxdg_set_min_size = NULL;
window->zxdg_set_max_size = NULL;
s = wl_array_add(&states, sizeof(*s));
*s = ZXDG_TOPLEVEL_V6_STATE_ACTIVATED;
_zxdg_toplevel_cb_configure(window, window->zxdg_toplevel,
- window->config.geometry.w,
- window->config.geometry.h, &states);
+ window->set_config.geometry.w,
+ window->set_config.geometry.h, &states);
wl_array_release(&states);
}
}
{
EINA_SAFETY_ON_NULL_RETURN_VAL(window, EINA_FALSE);
- return window->config.maximized;
+ return window->set_config.maximized;
}
EAPI void
EINA_SAFETY_ON_NULL_RETURN(window);
- prev = window->config.maximized;
+ prev = window->set_config.maximized;
maximized = !!maximized;
if (prev == maximized) return;
- if (!ecore_wl2_window_shell_surface_exists(window))
- window->config.maximized = maximized;
+ window->set_config.maximized = maximized;
if (maximized)
{
- window->saved = window->config.geometry;
+ window->saved = window->set_config.geometry;
if (window->zxdg_toplevel)
zxdg_toplevel_v6_set_maximized(window->zxdg_toplevel);
{
EINA_SAFETY_ON_NULL_RETURN_VAL(window, EINA_FALSE);
- return window->config.fullscreen;
+ return window->set_config.fullscreen;
}
EAPI void
EINA_SAFETY_ON_NULL_RETURN(window);
- prev = window->config.fullscreen;
+ prev = window->set_config.fullscreen;
fullscreen = !!fullscreen;
if (prev == fullscreen) return;
- if (!ecore_wl2_window_shell_surface_exists(window))
- window->config.fullscreen = fullscreen;
+ window->set_config.fullscreen = fullscreen;
if (fullscreen)
{
- window->saved = window->config.geometry;
+ window->saved = window->set_config.geometry;
if (window->zxdg_toplevel)
zxdg_toplevel_v6_set_fullscreen(window->zxdg_toplevel, NULL);
{
EINA_SAFETY_ON_NULL_RETURN(window);
- if (x) *x = window->config.geometry.x;
- if (y) *y = window->config.geometry.y;
- if (w) *w = window->config.geometry.w;
- if (h) *h = window->config.geometry.h;
+ if (x) *x = window->set_config.geometry.x;
+ if (y) *y = window->set_config.geometry.y;
+ if (w) *w = window->set_config.geometry.w;
+ if (h) *h = window->set_config.geometry.h;
}
EAPI void
{
EINA_SAFETY_ON_NULL_RETURN(window);
- if ((window->config.geometry.x == x) && (window->config.geometry.y == y) &&
- (window->config.geometry.w == w) && (window->config.geometry.h == h))
+ if ((window->set_config.geometry.x == x) &&
+ (window->set_config.geometry.y == y) &&
+ (window->set_config.geometry.w == w) &&
+ (window->set_config.geometry.h == h))
return;
- window->config.geometry.x = x;
- window->config.geometry.y = y;
- window->config.geometry.w = w;
- window->config.geometry.h = h;
+ window->set_config.geometry.x = x;
+ window->set_config.geometry.y = y;
+ window->set_config.geometry.w = w;
+ window->set_config.geometry.h = h;
if (window->zxdg_toplevel)
zxdg_surface_v6_set_window_geometry(window->zxdg_surface, x, y, w, h);
{
EINA_SAFETY_ON_NULL_RETURN_VAL(window, EINA_FALSE);
- return window->config.minimized;
+ return window->set_config.minimized;
}
EAPI void
EINA_SAFETY_ON_NULL_RETURN(window);
- prev = window->config.minimized;
+ prev = window->set_config.minimized;
iconified = !!iconified;
if (prev == iconified) return;
- window->config.minimized = iconified;
+ window->set_config.minimized = iconified;
if (iconified)
{
s = wl_array_add(&states, sizeof(*s));
*s = ZXDG_TOPLEVEL_V6_STATE_ACTIVATED;
_zxdg_toplevel_cb_configure(window, window->zxdg_toplevel,
- window->config.geometry.w,
- window->config.geometry.h, &states);
+ window->set_config.geometry.w,
+ window->set_config.geometry.h, &states);
wl_array_release(&states);
}
}
ecore_wl2_window_activated_get(const Ecore_Wl2_Window *window)
{
EINA_SAFETY_ON_NULL_RETURN_VAL(window, EINA_FALSE);
- return window->config.focused;
+ return window->req_config.focused;
}
EAPI Ecore_Wl2_Output *
EINA_SAFETY_ON_NULL_RETURN_VAL(window, NULL);
- x = window->config.geometry.x;
- y = window->config.geometry.y;
+ x = window->set_config.geometry.x;
+ y = window->set_config.geometry.y;
EINA_INLIST_FOREACH_SAFE(window->display->outputs, tmp, out)
{
{
EINA_SAFETY_ON_NULL_RETURN_VAL(window, EINA_FALSE);
- return window->config.resizing;
+ return window->req_config.resizing;
}