Same fscreen func for xdg and xwayland
This commit is contained in:
parent
dd2adb38ae
commit
bd222cb75d
46
dwl.c
46
dwl.c
|
@ -294,7 +294,6 @@ static struct wl_listener request_set_sel = {.notify = setsel};
|
||||||
#ifdef XWAYLAND
|
#ifdef XWAYLAND
|
||||||
static void activatex11(struct wl_listener *listener, void *data);
|
static void activatex11(struct wl_listener *listener, void *data);
|
||||||
static void createnotifyx11(struct wl_listener *listener, void *data);
|
static void createnotifyx11(struct wl_listener *listener, void *data);
|
||||||
static void fullscreenotifyx11(struct wl_listener *listener, void *data);
|
|
||||||
static Atom getatom(xcb_connection_t *xc, const char *name);
|
static Atom getatom(xcb_connection_t *xc, const char *name);
|
||||||
static void renderindependents(struct wlr_output *output, struct timespec *now);
|
static void renderindependents(struct wlr_output *output, struct timespec *now);
|
||||||
static void updatewindowtype(Client *c);
|
static void updatewindowtype(Client *c);
|
||||||
|
@ -609,6 +608,7 @@ createnotify(struct wl_listener *listener, void *data)
|
||||||
|
|
||||||
c->fullscreen.notify = fullscreenotify;
|
c->fullscreen.notify = fullscreenotify;
|
||||||
wl_signal_add(&xdg_surface->toplevel->events.request_fullscreen, &c->fullscreen);
|
wl_signal_add(&xdg_surface->toplevel->events.request_fullscreen, &c->fullscreen);
|
||||||
|
c->isfullscreen = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -679,18 +679,24 @@ destroyxdeco(struct wl_listener *listener, void *data)
|
||||||
void
|
void
|
||||||
fullscreenotify(struct wl_listener *listener, void *data) {
|
fullscreenotify(struct wl_listener *listener, void *data) {
|
||||||
Client *c = wl_container_of(listener, c, fullscreen);
|
Client *c = wl_container_of(listener, c, fullscreen);
|
||||||
wlr_xdg_toplevel_set_fullscreen(
|
c->isfullscreen = !c->isfullscreen;
|
||||||
c->surface.xdg, !c->surface.xdg->toplevel->current.fullscreen);
|
|
||||||
c->bw = (int)c->surface.xdg->toplevel->current.fullscreen * borderpx;
|
|
||||||
|
|
||||||
if (c->surface.xdg->toplevel->current.fullscreen) { /* fullscreen off */
|
#ifdef XWAYLAND
|
||||||
resize(c, c->prevx, c->prevy, c->prevwidth, c->prevheight, 0);
|
if (c->type == X11Managed)
|
||||||
} else { /* fullscreen on */
|
wlr_xwayland_surface_set_fullscreen(c->surface.xwayland, c->isfullscreen);
|
||||||
|
else
|
||||||
|
#endif
|
||||||
|
wlr_xdg_toplevel_set_fullscreen(c->surface.xdg, c->isfullscreen);
|
||||||
|
|
||||||
|
c->bw = ((int)(!c->isfullscreen)) * borderpx;
|
||||||
|
if (c->isfullscreen) {
|
||||||
c->prevx = c->geom.x;
|
c->prevx = c->geom.x;
|
||||||
c->prevy = c->geom.y;
|
c->prevy = c->geom.y;
|
||||||
c->prevheight = c->geom.height;
|
c->prevheight = c->geom.height;
|
||||||
c->prevwidth = c->geom.width;
|
c->prevwidth = c->geom.width;
|
||||||
resize(c, c->mon->w.x, c->mon->w.y, c->mon->w.width, c->mon->w.height, 0);
|
resize(c, c->mon->w.x, c->mon->w.y, c->mon->w.width, c->mon->w.height, 0);
|
||||||
|
} else {
|
||||||
|
resize(c, c->prevx, c->prevy, c->prevwidth, c->prevheight, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1850,35 +1856,11 @@ createnotifyx11(struct wl_listener *listener, void *data)
|
||||||
c->destroy.notify = destroynotify;
|
c->destroy.notify = destroynotify;
|
||||||
wl_signal_add(&xwayland_surface->events.destroy, &c->destroy);
|
wl_signal_add(&xwayland_surface->events.destroy, &c->destroy);
|
||||||
|
|
||||||
c->fullscreen.notify = fullscreenotifyx11;
|
c->fullscreen.notify = fullscreenotify;
|
||||||
wl_signal_add(&xwayland_surface->events.request_fullscreen, &c->fullscreen);
|
wl_signal_add(&xwayland_surface->events.request_fullscreen, &c->fullscreen);
|
||||||
c->isfullscreen = false;
|
c->isfullscreen = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
|
||||||
fullscreenotifyx11(struct wl_listener *listener, void *data) {
|
|
||||||
FILE *xway = fopen("/tmp/dwl/xway", "a");
|
|
||||||
Client *c;
|
|
||||||
c = wl_container_of(listener, c, fullscreen);
|
|
||||||
c->isfullscreen = !c->isfullscreen;
|
|
||||||
wlr_xwayland_surface_set_fullscreen(
|
|
||||||
c->surface.xwayland, c->isfullscreen);
|
|
||||||
c->bw = ((int)(!c->isfullscreen)) * borderpx;
|
|
||||||
|
|
||||||
fprintf(xway, "fullscreen: %d\n", c->surface.xwayland->fullscreen);
|
|
||||||
fclose(xway);
|
|
||||||
|
|
||||||
if (c->isfullscreen) { /* fullscreen off */
|
|
||||||
c->prevx = c->geom.x;
|
|
||||||
c->prevy = c->geom.y;
|
|
||||||
c->prevheight = c->geom.height;
|
|
||||||
c->prevwidth = c->geom.width;
|
|
||||||
resize(c, c->mon->w.x, c->mon->w.y, c->mon->w.width, c->mon->w.height, 0);
|
|
||||||
} else { /* fullscreen on */
|
|
||||||
resize(c, c->prevx, c->prevy, c->prevwidth, c->prevheight, 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Atom
|
Atom
|
||||||
getatom(xcb_connection_t *xc, const char *name)
|
getatom(xcb_connection_t *xc, const char *name)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue