Remove DWL
This commit is contained in:
3
.gitignore
vendored
3
.gitignore
vendored
@@ -14,6 +14,3 @@ temp/
|
|||||||
|
|
||||||
dotfiles/.local/share/icons/hicolor
|
dotfiles/.local/share/icons/hicolor
|
||||||
|
|
||||||
dwl/*.o
|
|
||||||
dwl/dwl
|
|
||||||
dwl/config.h
|
|
||||||
|
|||||||
76
dwl/Makefile
76
dwl/Makefile
@@ -1,76 +0,0 @@
|
|||||||
.POSIX:
|
|
||||||
.SUFFIXES:
|
|
||||||
|
|
||||||
include config.mk
|
|
||||||
|
|
||||||
# flags for compiling
|
|
||||||
DWLCPPFLAGS = -I. -DWLR_USE_UNSTABLE -D_POSIX_C_SOURCE=200809L -DVERSION=\"$(VERSION)\" $(XWAYLAND)
|
|
||||||
DWLDEVCFLAGS = -g -pedantic -Wall -Wextra -Wdeclaration-after-statement -Wno-unused-parameter -Wshadow -Wunused-macros\
|
|
||||||
-Werror=strict-prototypes -Werror=implicit -Werror=return-type -Werror=incompatible-pointer-types -Wfloat-conversion
|
|
||||||
|
|
||||||
# CFLAGS / LDFLAGS
|
|
||||||
PKGS = wlroots wayland-server xkbcommon libinput $(XLIBS)
|
|
||||||
DWLCFLAGS = `$(PKG_CONFIG) --cflags $(PKGS)` $(DWLCPPFLAGS) $(DWLDEVCFLAGS) $(CFLAGS)
|
|
||||||
LDLIBS = `$(PKG_CONFIG) --libs $(PKGS)` $(LIBS)
|
|
||||||
|
|
||||||
all: dwl
|
|
||||||
dwl: dwl.o util.o dwl-ipc-unstable-v2-protocol.o
|
|
||||||
$(CC) dwl.o util.o dwl-ipc-unstable-v2-protocol.o $(LDLIBS) $(LDFLAGS) $(DWLCFLAGS) -o $@
|
|
||||||
dwl.o: dwl.c config.mk config.h client.h cursor-shape-v1-protocol.h pointer-constraints-unstable-v1-protocol.h wlr-layer-shell-unstable-v1-protocol.h xdg-shell-protocol.h dwl-ipc-unstable-v2-protocol.h
|
|
||||||
util.o: util.c util.h
|
|
||||||
dwl-ipc-unstable-v2-protocol.o: dwl-ipc-unstable-v2-protocol.c dwl-ipc-unstable-v2-protocol.h
|
|
||||||
|
|
||||||
# wayland-scanner is a tool which generates C headers and rigging for Wayland
|
|
||||||
# protocols, which are specified in XML. wlroots requires you to rig these up
|
|
||||||
# to your build system yourself and provide them in the include path.
|
|
||||||
WAYLAND_SCANNER = `$(PKG_CONFIG) --variable=wayland_scanner wayland-scanner`
|
|
||||||
WAYLAND_PROTOCOLS = `$(PKG_CONFIG) --variable=pkgdatadir wayland-protocols`
|
|
||||||
|
|
||||||
cursor-shape-v1-protocol.h:
|
|
||||||
$(WAYLAND_SCANNER) server-header \
|
|
||||||
$(WAYLAND_PROTOCOLS)/staging/cursor-shape/cursor-shape-v1.xml $@
|
|
||||||
pointer-constraints-unstable-v1-protocol.h:
|
|
||||||
$(WAYLAND_SCANNER) server-header \
|
|
||||||
$(WAYLAND_PROTOCOLS)/unstable/pointer-constraints/pointer-constraints-unstable-v1.xml $@
|
|
||||||
wlr-layer-shell-unstable-v1-protocol.h:
|
|
||||||
$(WAYLAND_SCANNER) server-header \
|
|
||||||
protocols/wlr-layer-shell-unstable-v1.xml $@
|
|
||||||
xdg-shell-protocol.h:
|
|
||||||
$(WAYLAND_SCANNER) server-header \
|
|
||||||
$(WAYLAND_PROTOCOLS)/stable/xdg-shell/xdg-shell.xml $@
|
|
||||||
dwl-ipc-unstable-v2-protocol.h:
|
|
||||||
$(WAYLAND_SCANNER) server-header \
|
|
||||||
protocols/dwl-ipc-unstable-v2.xml $@
|
|
||||||
dwl-ipc-unstable-v2-protocol.c:
|
|
||||||
$(WAYLAND_SCANNER) private-code \
|
|
||||||
protocols/dwl-ipc-unstable-v2.xml $@
|
|
||||||
|
|
||||||
config.h:
|
|
||||||
cp config.def.h $@
|
|
||||||
clean:
|
|
||||||
rm -f dwl *.o *-protocol.h
|
|
||||||
|
|
||||||
dist: clean
|
|
||||||
mkdir -p dwl-$(VERSION)
|
|
||||||
cp -R LICENSE* Makefile CHANGELOG.md README.md client.h config.def.h\
|
|
||||||
config.mk protocols dwl.1 dwl.c util.c util.h dwl.desktop\
|
|
||||||
dwl-$(VERSION)
|
|
||||||
tar -caf dwl-$(VERSION).tar.gz dwl-$(VERSION)
|
|
||||||
rm -rf dwl-$(VERSION)
|
|
||||||
|
|
||||||
install: dwl
|
|
||||||
mkdir -p $(DESTDIR)$(PREFIX)/bin
|
|
||||||
cp -f dwl $(DESTDIR)$(PREFIX)/bin
|
|
||||||
chmod 755 $(DESTDIR)$(PREFIX)/bin/dwl
|
|
||||||
mkdir -p $(DESTDIR)$(MANDIR)/man1
|
|
||||||
cp -f dwl.1 $(DESTDIR)$(MANDIR)/man1
|
|
||||||
chmod 644 $(DESTDIR)$(MANDIR)/man1/dwl.1
|
|
||||||
mkdir -p $(DESTDIR)$(DATADIR)/wayland-sessions
|
|
||||||
cp -f dwl.desktop $(DESTDIR)$(DATADIR)/wayland-sessions/dwl.desktop
|
|
||||||
chmod 644 $(DESTDIR)$(DATADIR)/wayland-sessions/dwl.desktop
|
|
||||||
uninstall:
|
|
||||||
rm -f $(DESTDIR)$(PREFIX)/bin/dwl $(DESTDIR)$(MANDIR)/man1/dwl.1 $(DESTDIR)$(DATADIR)/wayland-sessions/dwl.desktop
|
|
||||||
|
|
||||||
.SUFFIXES: .c .o
|
|
||||||
.c.o:
|
|
||||||
$(CC) $(CPPFLAGS) $(DWLCFLAGS) -c $<
|
|
||||||
408
dwl/client.h
408
dwl/client.h
@@ -1,408 +0,0 @@
|
|||||||
/*
|
|
||||||
* Attempt to consolidate unavoidable suck into one file, away from dwl.c. This
|
|
||||||
* file is not meant to be pretty. We use a .h file with static inline
|
|
||||||
* functions instead of a separate .c module, or function pointers like sway, so
|
|
||||||
* that they will simply compile out if the chosen #defines leave them unused.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* Leave these functions first; they're used in the others */
|
|
||||||
static inline int
|
|
||||||
client_is_x11(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
return c->type == X11;
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline struct wlr_surface *
|
|
||||||
client_surface(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return c->surface.xwayland->surface;
|
|
||||||
#endif
|
|
||||||
return c->surface.xdg->surface;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
toplevel_from_wlr_surface(struct wlr_surface *s, Client **pc, LayerSurface **pl)
|
|
||||||
{
|
|
||||||
struct wlr_xdg_surface *xdg_surface, *tmp_xdg_surface;
|
|
||||||
struct wlr_surface *root_surface;
|
|
||||||
struct wlr_layer_surface_v1 *layer_surface;
|
|
||||||
Client *c = NULL;
|
|
||||||
LayerSurface *l = NULL;
|
|
||||||
int type = -1;
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
struct wlr_xwayland_surface *xsurface;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (!s)
|
|
||||||
return -1;
|
|
||||||
root_surface = wlr_surface_get_root_surface(s);
|
|
||||||
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if ((xsurface = wlr_xwayland_surface_try_from_wlr_surface(root_surface))) {
|
|
||||||
c = xsurface->data;
|
|
||||||
type = c->type;
|
|
||||||
goto end;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if ((layer_surface = wlr_layer_surface_v1_try_from_wlr_surface(root_surface))) {
|
|
||||||
l = layer_surface->data;
|
|
||||||
type = LayerShell;
|
|
||||||
goto end;
|
|
||||||
}
|
|
||||||
|
|
||||||
xdg_surface = wlr_xdg_surface_try_from_wlr_surface(root_surface);
|
|
||||||
while (xdg_surface) {
|
|
||||||
tmp_xdg_surface = NULL;
|
|
||||||
switch (xdg_surface->role) {
|
|
||||||
case WLR_XDG_SURFACE_ROLE_POPUP:
|
|
||||||
if (!xdg_surface->popup || !xdg_surface->popup->parent)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
tmp_xdg_surface = wlr_xdg_surface_try_from_wlr_surface(xdg_surface->popup->parent);
|
|
||||||
|
|
||||||
if (!tmp_xdg_surface)
|
|
||||||
return toplevel_from_wlr_surface(xdg_surface->popup->parent, pc, pl);
|
|
||||||
|
|
||||||
xdg_surface = tmp_xdg_surface;
|
|
||||||
break;
|
|
||||||
case WLR_XDG_SURFACE_ROLE_TOPLEVEL:
|
|
||||||
c = xdg_surface->data;
|
|
||||||
type = c->type;
|
|
||||||
goto end;
|
|
||||||
case WLR_XDG_SURFACE_ROLE_NONE:
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
end:
|
|
||||||
if (pl)
|
|
||||||
*pl = l;
|
|
||||||
if (pc)
|
|
||||||
*pc = c;
|
|
||||||
return type;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* The others */
|
|
||||||
static inline void
|
|
||||||
client_activate_surface(struct wlr_surface *s, int activated)
|
|
||||||
{
|
|
||||||
struct wlr_xdg_toplevel *toplevel;
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
struct wlr_xwayland_surface *xsurface;
|
|
||||||
if ((xsurface = wlr_xwayland_surface_try_from_wlr_surface(s))) {
|
|
||||||
wlr_xwayland_surface_activate(xsurface, activated);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if ((toplevel = wlr_xdg_toplevel_try_from_wlr_surface(s)))
|
|
||||||
wlr_xdg_toplevel_set_activated(toplevel, activated);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline uint32_t
|
|
||||||
client_set_bounds(Client *c, int32_t width, int32_t height)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
if (wl_resource_get_version(c->surface.xdg->toplevel->resource) >=
|
|
||||||
XDG_TOPLEVEL_CONFIGURE_BOUNDS_SINCE_VERSION && width >= 0 && height >= 0
|
|
||||||
&& (c->bounds.width != width || c->bounds.height != height)) {
|
|
||||||
c->bounds.width = width;
|
|
||||||
c->bounds.height = height;
|
|
||||||
return wlr_xdg_toplevel_set_bounds(c->surface.xdg->toplevel, width, height);
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline const char *
|
|
||||||
client_get_appid(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return c->surface.xwayland->class;
|
|
||||||
#endif
|
|
||||||
return c->surface.xdg->toplevel->app_id;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_get_clip(Client *c, struct wlr_box *clip)
|
|
||||||
{
|
|
||||||
struct wlr_box xdg_geom = {0};
|
|
||||||
*clip = (struct wlr_box){
|
|
||||||
.x = 0,
|
|
||||||
.y = 0,
|
|
||||||
.width = c->geom.width - c->bw,
|
|
||||||
.height = c->geom.height - c->bw,
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
wlr_xdg_surface_get_geometry(c->surface.xdg, &xdg_geom);
|
|
||||||
clip->x = xdg_geom.x;
|
|
||||||
clip->y = xdg_geom.y;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_get_geometry(Client *c, struct wlr_box *geom)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c)) {
|
|
||||||
geom->x = c->surface.xwayland->x;
|
|
||||||
geom->y = c->surface.xwayland->y;
|
|
||||||
geom->width = c->surface.xwayland->width;
|
|
||||||
geom->height = c->surface.xwayland->height;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
wlr_xdg_surface_get_geometry(c->surface.xdg, geom);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline Client *
|
|
||||||
client_get_parent(Client *c)
|
|
||||||
{
|
|
||||||
Client *p = NULL;
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c)) {
|
|
||||||
if (c->surface.xwayland->parent)
|
|
||||||
toplevel_from_wlr_surface(c->surface.xwayland->parent->surface, &p, NULL);
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if (c->surface.xdg->toplevel->parent)
|
|
||||||
toplevel_from_wlr_surface(c->surface.xdg->toplevel->parent->base->surface, &p, NULL);
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_has_children(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return !wl_list_empty(&c->surface.xwayland->children);
|
|
||||||
#endif
|
|
||||||
/* surface.xdg->link is never empty because it always contains at least the
|
|
||||||
* surface itself. */
|
|
||||||
return wl_list_length(&c->surface.xdg->link) > 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline const char *
|
|
||||||
client_get_title(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return c->surface.xwayland->title;
|
|
||||||
#endif
|
|
||||||
return c->surface.xdg->toplevel->title;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_is_float_type(Client *c)
|
|
||||||
{
|
|
||||||
struct wlr_xdg_toplevel *toplevel;
|
|
||||||
struct wlr_xdg_toplevel_state state;
|
|
||||||
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c)) {
|
|
||||||
struct wlr_xwayland_surface *surface = c->surface.xwayland;
|
|
||||||
xcb_size_hints_t *size_hints = surface->size_hints;
|
|
||||||
size_t i;
|
|
||||||
if (surface->modal)
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
for (i = 0; i < surface->window_type_len; i++)
|
|
||||||
if (surface->window_type[i] == netatom[NetWMWindowTypeDialog]
|
|
||||||
|| surface->window_type[i] == netatom[NetWMWindowTypeSplash]
|
|
||||||
|| surface->window_type[i] == netatom[NetWMWindowTypeToolbar]
|
|
||||||
|| surface->window_type[i] == netatom[NetWMWindowTypeUtility])
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
return size_hints && size_hints->min_width > 0 && size_hints->min_height > 0
|
|
||||||
&& (size_hints->max_width == size_hints->min_width
|
|
||||||
|| size_hints->max_height == size_hints->min_height);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
toplevel = c->surface.xdg->toplevel;
|
|
||||||
state = toplevel->current;
|
|
||||||
return toplevel->parent || (state.min_width != 0 && state.min_height != 0
|
|
||||||
&& (state.min_width == state.max_width
|
|
||||||
|| state.min_height == state.max_height));
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_is_rendered_on_mon(Client *c, Monitor *m)
|
|
||||||
{
|
|
||||||
/* This is needed for when you don't want to check formal assignment,
|
|
||||||
* but rather actual displaying of the pixels.
|
|
||||||
* Usually VISIBLEON suffices and is also faster. */
|
|
||||||
struct wlr_surface_output *s;
|
|
||||||
int unused_lx, unused_ly;
|
|
||||||
if (!wlr_scene_node_coords(&c->scene->node, &unused_lx, &unused_ly))
|
|
||||||
return 0;
|
|
||||||
wl_list_for_each(s, &client_surface(c)->current_outputs, link)
|
|
||||||
if (s->output == m->wlr_output)
|
|
||||||
return 1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_is_stopped(Client *c)
|
|
||||||
{
|
|
||||||
int pid;
|
|
||||||
siginfo_t in = {0};
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return 0;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
wl_client_get_credentials(c->surface.xdg->client->client, &pid, NULL, NULL);
|
|
||||||
if (waitid(P_PID, pid, &in, WNOHANG|WCONTINUED|WSTOPPED|WNOWAIT) < 0) {
|
|
||||||
/* This process is not our child process, while is very unluckely that
|
|
||||||
* it is stopped, in order to do not skip frames assume that it is. */
|
|
||||||
if (errno == ECHILD)
|
|
||||||
return 1;
|
|
||||||
} else if (in.si_pid) {
|
|
||||||
if (in.si_code == CLD_STOPPED || in.si_code == CLD_TRAPPED)
|
|
||||||
return 1;
|
|
||||||
if (in.si_code == CLD_CONTINUED)
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_is_unmanaged(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return c->surface.xwayland->override_redirect;
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_notify_enter(struct wlr_surface *s, struct wlr_keyboard *kb)
|
|
||||||
{
|
|
||||||
if (kb)
|
|
||||||
wlr_seat_keyboard_notify_enter(seat, s, kb->keycodes,
|
|
||||||
kb->num_keycodes, &kb->modifiers);
|
|
||||||
else
|
|
||||||
wlr_seat_keyboard_notify_enter(seat, s, NULL, 0, NULL);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_restack_surface(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
wlr_xwayland_surface_restack(c->surface.xwayland, NULL,
|
|
||||||
XCB_STACK_MODE_ABOVE);
|
|
||||||
#endif
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_send_close(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c)) {
|
|
||||||
wlr_xwayland_surface_close(c->surface.xwayland);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
wlr_xdg_toplevel_send_close(c->surface.xdg->toplevel);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_set_border_color(Client *c, const float color[static 4])
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
for (i = 0; i < 4; i++)
|
|
||||||
wlr_scene_rect_set_color(c->border[i], color);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_set_fullscreen(Client *c, int fullscreen)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c)) {
|
|
||||||
wlr_xwayland_surface_set_fullscreen(c->surface.xwayland, fullscreen);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
wlr_xdg_toplevel_set_fullscreen(c->surface.xdg->toplevel, fullscreen);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline uint32_t
|
|
||||||
client_set_size(Client *c, uint32_t width, uint32_t height)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c)) {
|
|
||||||
wlr_xwayland_surface_configure(c->surface.xwayland,
|
|
||||||
c->geom.x, c->geom.y, width, height);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if ((int32_t)width == c->surface.xdg->toplevel->current.width
|
|
||||||
&& (int32_t)height == c->surface.xdg->toplevel->current.height)
|
|
||||||
return 0;
|
|
||||||
return wlr_xdg_toplevel_set_size(c->surface.xdg->toplevel, (int32_t)width, (int32_t)height);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_set_tiled(Client *c, uint32_t edges)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return;
|
|
||||||
#endif
|
|
||||||
if (wl_resource_get_version(c->surface.xdg->toplevel->resource)
|
|
||||||
>= XDG_TOPLEVEL_STATE_TILED_RIGHT_SINCE_VERSION) {
|
|
||||||
wlr_xdg_toplevel_set_tiled(c->surface.xdg->toplevel, edges);
|
|
||||||
} else {
|
|
||||||
wlr_xdg_toplevel_set_maximized(c->surface.xdg->toplevel, edges != WLR_EDGE_NONE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void
|
|
||||||
client_set_suspended(Client *c, int suspended)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
wlr_xdg_toplevel_set_suspended(c->surface.xdg->toplevel, suspended);
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_wants_focus(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
return client_is_unmanaged(c)
|
|
||||||
&& wlr_xwayland_or_surface_wants_focus(c->surface.xwayland)
|
|
||||||
&& wlr_xwayland_icccm_input_model(c->surface.xwayland) != WLR_ICCCM_INPUT_MODEL_NONE;
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline int
|
|
||||||
client_wants_fullscreen(Client *c)
|
|
||||||
{
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
if (client_is_x11(c))
|
|
||||||
return c->surface.xwayland->fullscreen;
|
|
||||||
#endif
|
|
||||||
return c->surface.xdg->toplevel->requested.fullscreen;
|
|
||||||
}
|
|
||||||
189
dwl/config.def.h
189
dwl/config.def.h
@@ -1,189 +0,0 @@
|
|||||||
/* Taken from https://github.com/djpohly/dwl/issues/466 */
|
|
||||||
#define COLOR(hex) { ((hex >> 24) & 0xFF) / 255.0f, \
|
|
||||||
((hex >> 16) & 0xFF) / 255.0f, \
|
|
||||||
((hex >> 8) & 0xFF) / 255.0f, \
|
|
||||||
(hex & 0xFF) / 255.0f }
|
|
||||||
/* appearance */
|
|
||||||
static const int sloppyfocus = 1; /* focus follows mouse */
|
|
||||||
static const int bypass_surface_visibility = 0; /* 1 means idle inhibitors will disable idle tracking even if it's surface isn't visible */
|
|
||||||
static const int smartgaps = 0; /* 1 means no outer gap when there is only one window */
|
|
||||||
static int gaps = 1; /* 1 means gaps between windows are added */
|
|
||||||
static const unsigned int gappx = 5; /* gap pixel between windows */
|
|
||||||
static const unsigned int borderpx = 1; /* border pixel of windows */
|
|
||||||
static const float rootcolor[] = COLOR(0x222222ff);
|
|
||||||
static const float bordercolor[] = COLOR(0x444444ff);
|
|
||||||
static const float focuscolor[] = COLOR(0x005577ff);
|
|
||||||
static const float urgentcolor[] = COLOR(0xff0000ff);
|
|
||||||
/* This conforms to the xdg-protocol. Set the alpha to zero to restore the old behavior */
|
|
||||||
static const float fullscreen_bg[] = {0.1f, 0.1f, 0.1f, 1.0f}; /* You can also use glsl colors */
|
|
||||||
|
|
||||||
/* tagging - TAGCOUNT must be no greater than 31 */
|
|
||||||
#define TAGCOUNT (9)
|
|
||||||
|
|
||||||
/* logging */
|
|
||||||
static int log_level = WLR_ERROR;
|
|
||||||
|
|
||||||
/* Autostart */
|
|
||||||
static const char *const autostart[] = {
|
|
||||||
"swaybg", NULL,
|
|
||||||
"nextcloud", "--background", NULL,
|
|
||||||
"/usr/libexec/xdg-desktop-portal", "-r", NULL,
|
|
||||||
"waybar", NULL,
|
|
||||||
"dunst", NULL,
|
|
||||||
NULL /* terminate */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
static const Rule rules[] = {
|
|
||||||
/* app_id title tags mask isfloating monitor */
|
|
||||||
/* examples: */
|
|
||||||
{ "Gimp_EXAMPLE", NULL, 0, 1, -1 }, /* Start on currently visible tags floating, not tiled */
|
|
||||||
{ "firefox_EXAMPLE", NULL, 1 << 8, 0, -1 }, /* Start on ONLY tag "9" */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* layout(s) */
|
|
||||||
static const Layout layouts[] = {
|
|
||||||
/* symbol arrange function */
|
|
||||||
{ "[]=", tile },
|
|
||||||
{ "><>", NULL }, /* no layout function means floating behavior */
|
|
||||||
{ "[M]", monocle },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* monitors */
|
|
||||||
/* NOTE: ALWAYS add a fallback rule, even if you are completely sure it won't be used */
|
|
||||||
static const MonitorRule monrules[] = {
|
|
||||||
/* name mfact nmaster scale layout rotate/reflect x y */
|
|
||||||
/* example of a HiDPI monitor: */
|
|
||||||
{ "DP-1", 0.5f, 1, 2, &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, -1, -1 },
|
|
||||||
/* defaults */
|
|
||||||
{ NULL, 0.55f, 1, 1, &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, -1, -1 },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* keyboard */
|
|
||||||
static const struct xkb_rule_names xkb_rules = {
|
|
||||||
/* can specify fields: rules, model, layout, variant, options */
|
|
||||||
/* example:
|
|
||||||
.options = "ctrl:nocaps",
|
|
||||||
*/
|
|
||||||
.options = NULL,
|
|
||||||
.layout = "pt",
|
|
||||||
};
|
|
||||||
|
|
||||||
static const int repeat_rate = 25;
|
|
||||||
static const int repeat_delay = 600;
|
|
||||||
|
|
||||||
/* Trackpad */
|
|
||||||
static const int tap_to_click = 1;
|
|
||||||
static const int tap_and_drag = 1;
|
|
||||||
static const int drag_lock = 1;
|
|
||||||
static const int natural_scrolling = 0;
|
|
||||||
static const int disable_while_typing = 1;
|
|
||||||
static const int left_handed = 0;
|
|
||||||
static const int middle_button_emulation = 1;
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_SCROLL_NO_SCROLL
|
|
||||||
LIBINPUT_CONFIG_SCROLL_2FG
|
|
||||||
LIBINPUT_CONFIG_SCROLL_EDGE
|
|
||||||
LIBINPUT_CONFIG_SCROLL_ON_BUTTON_DOWN
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_scroll_method scroll_method = LIBINPUT_CONFIG_SCROLL_2FG;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_CLICK_METHOD_NONE
|
|
||||||
LIBINPUT_CONFIG_CLICK_METHOD_BUTTON_AREAS
|
|
||||||
LIBINPUT_CONFIG_CLICK_METHOD_CLICKFINGER
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_click_method click_method = LIBINPUT_CONFIG_CLICK_METHOD_BUTTON_AREAS;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_SEND_EVENTS_ENABLED
|
|
||||||
LIBINPUT_CONFIG_SEND_EVENTS_DISABLED
|
|
||||||
LIBINPUT_CONFIG_SEND_EVENTS_DISABLED_ON_EXTERNAL_MOUSE
|
|
||||||
*/
|
|
||||||
static const uint32_t send_events_mode = LIBINPUT_CONFIG_SEND_EVENTS_ENABLED;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_ACCEL_PROFILE_FLAT
|
|
||||||
LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_accel_profile accel_profile = LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE;
|
|
||||||
static const double accel_speed = 0.0;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_TAP_MAP_LRM -- 1/2/3 finger tap maps to left/right/middle
|
|
||||||
LIBINPUT_CONFIG_TAP_MAP_LMR -- 1/2/3 finger tap maps to left/middle/right
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_tap_button_map button_map = LIBINPUT_CONFIG_TAP_MAP_LRM;
|
|
||||||
|
|
||||||
/* If you want to use the windows key for MODKEY, use WLR_MODIFIER_LOGO */
|
|
||||||
#define MODKEY WLR_MODIFIER_LOGO
|
|
||||||
|
|
||||||
#define TAGKEYS(KEY,SKEY,TAG) \
|
|
||||||
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|WLR_MODIFIER_CTRL, KEY, toggleview, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, SKEY, tag, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|WLR_MODIFIER_CTRL|WLR_MODIFIER_SHIFT,SKEY,toggletag, {.ui = 1 << TAG} }
|
|
||||||
|
|
||||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
|
||||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
|
||||||
|
|
||||||
/* commands */
|
|
||||||
static const char *termcmd[] = { "foot", NULL };
|
|
||||||
static const char *menucmd[] = { "wofi", "--show", "run", NULL };
|
|
||||||
static const char *lockcmd[] = { "swaylock", "-f", NULL };
|
|
||||||
|
|
||||||
static const Key keys[] = {
|
|
||||||
/* Note that Shift changes certain key codes: c -> C, 2 -> at, etc. */
|
|
||||||
/* modifier key function argument */
|
|
||||||
{ MODKEY, XKB_KEY_p, spawn, {.v = menucmd} },
|
|
||||||
{ MODKEY, XKB_KEY_Return, spawn, {.v = termcmd} },
|
|
||||||
{ MODKEY, XKB_KEY_q, spawn, {.v = lockcmd} },
|
|
||||||
{ MODKEY, XKB_KEY_b, togglebar, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_j, focusstack, {.i = +1} },
|
|
||||||
{ MODKEY, XKB_KEY_k, focusstack, {.i = -1} },
|
|
||||||
{ MODKEY, XKB_KEY_i, incnmaster, {.i = +1} },
|
|
||||||
{ MODKEY, XKB_KEY_d, incnmaster, {.i = -1} },
|
|
||||||
{ MODKEY, XKB_KEY_h, setmfact, {.f = -0.05f} },
|
|
||||||
{ MODKEY, XKB_KEY_l, setmfact, {.f = +0.05f} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_Return, zoom, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_Tab, view, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_g, togglegaps, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_c, killclient, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_t, setlayout, {.v = &layouts[0]} },
|
|
||||||
{ MODKEY, XKB_KEY_f, setlayout, {.v = &layouts[1]} },
|
|
||||||
{ MODKEY, XKB_KEY_m, setlayout, {.v = &layouts[2]} },
|
|
||||||
{ MODKEY, XKB_KEY_space, setlayout, {0} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_space, togglefloating, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_e, togglefullscreen, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_0, view, {.ui = ~0} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_parenright, tag, {.ui = ~0} },
|
|
||||||
{ MODKEY, XKB_KEY_comma, focusmon, {.i = WLR_DIRECTION_LEFT} },
|
|
||||||
{ MODKEY, XKB_KEY_period, focusmon, {.i = WLR_DIRECTION_RIGHT} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_less, tagmon, {.i = WLR_DIRECTION_LEFT} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_greater, tagmon, {.i = WLR_DIRECTION_RIGHT} },
|
|
||||||
TAGKEYS( XKB_KEY_1, XKB_KEY_exclam, 0),
|
|
||||||
TAGKEYS( XKB_KEY_2, XKB_KEY_at, 1),
|
|
||||||
TAGKEYS( XKB_KEY_3, XKB_KEY_numbersign, 2),
|
|
||||||
TAGKEYS( XKB_KEY_4, XKB_KEY_dollar, 3),
|
|
||||||
TAGKEYS( XKB_KEY_5, XKB_KEY_percent, 4),
|
|
||||||
TAGKEYS( XKB_KEY_6, XKB_KEY_asciicircum, 5),
|
|
||||||
TAGKEYS( XKB_KEY_7, XKB_KEY_ampersand, 6),
|
|
||||||
TAGKEYS( XKB_KEY_8, XKB_KEY_asterisk, 7),
|
|
||||||
TAGKEYS( XKB_KEY_9, XKB_KEY_parenleft, 8),
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_Q, quit, {0} },
|
|
||||||
|
|
||||||
/* Ctrl-Alt-Backspace and Ctrl-Alt-Fx used to be handled by X server */
|
|
||||||
{ WLR_MODIFIER_CTRL|WLR_MODIFIER_ALT,XKB_KEY_Terminate_Server, quit, {0} },
|
|
||||||
/* Ctrl-Alt-Fx is used to switch to another VT, if you don't know what a VT is
|
|
||||||
* do not remove them.
|
|
||||||
*/
|
|
||||||
#define CHVT(n) { WLR_MODIFIER_CTRL|WLR_MODIFIER_ALT,XKB_KEY_XF86Switch_VT_##n, chvt, {.ui = (n)} }
|
|
||||||
CHVT(1), CHVT(2), CHVT(3), CHVT(4), CHVT(5), CHVT(6),
|
|
||||||
CHVT(7), CHVT(8), CHVT(9), CHVT(10), CHVT(11), CHVT(12),
|
|
||||||
};
|
|
||||||
|
|
||||||
static const Button buttons[] = {
|
|
||||||
{ MODKEY, BTN_LEFT, moveresize, {.ui = CurMove} },
|
|
||||||
{ MODKEY, BTN_MIDDLE, togglefloating, {0} },
|
|
||||||
{ MODKEY, BTN_RIGHT, moveresize, {.ui = CurResize} },
|
|
||||||
};
|
|
||||||
189
dwl/config.h
189
dwl/config.h
@@ -1,189 +0,0 @@
|
|||||||
/* Taken from https://github.com/djpohly/dwl/issues/466 */
|
|
||||||
#define COLOR(hex) { ((hex >> 24) & 0xFF) / 255.0f, \
|
|
||||||
((hex >> 16) & 0xFF) / 255.0f, \
|
|
||||||
((hex >> 8) & 0xFF) / 255.0f, \
|
|
||||||
(hex & 0xFF) / 255.0f }
|
|
||||||
/* appearance */
|
|
||||||
static const int sloppyfocus = 1; /* focus follows mouse */
|
|
||||||
static const int bypass_surface_visibility = 0; /* 1 means idle inhibitors will disable idle tracking even if it's surface isn't visible */
|
|
||||||
static const int smartgaps = 0; /* 1 means no outer gap when there is only one window */
|
|
||||||
static int gaps = 1; /* 1 means gaps between windows are added */
|
|
||||||
static const unsigned int gappx = 5; /* gap pixel between windows */
|
|
||||||
static const unsigned int borderpx = 1; /* border pixel of windows */
|
|
||||||
static const float rootcolor[] = COLOR(0x222222ff);
|
|
||||||
static const float bordercolor[] = COLOR(0x444444ff);
|
|
||||||
static const float focuscolor[] = COLOR(0x005577ff);
|
|
||||||
static const float urgentcolor[] = COLOR(0xff0000ff);
|
|
||||||
/* This conforms to the xdg-protocol. Set the alpha to zero to restore the old behavior */
|
|
||||||
static const float fullscreen_bg[] = {0.1f, 0.1f, 0.1f, 1.0f}; /* You can also use glsl colors */
|
|
||||||
|
|
||||||
/* tagging - TAGCOUNT must be no greater than 31 */
|
|
||||||
#define TAGCOUNT (9)
|
|
||||||
|
|
||||||
/* logging */
|
|
||||||
static int log_level = WLR_ERROR;
|
|
||||||
|
|
||||||
/* Autostart */
|
|
||||||
static const char *const autostart[] = {
|
|
||||||
"swaybg", NULL,
|
|
||||||
"nextcloud", "--background", NULL,
|
|
||||||
"/usr/libexec/xdg-desktop-portal", "-r", NULL,
|
|
||||||
"waybar", NULL,
|
|
||||||
"dunst", NULL,
|
|
||||||
NULL /* terminate */
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
static const Rule rules[] = {
|
|
||||||
/* app_id title tags mask isfloating monitor */
|
|
||||||
/* examples: */
|
|
||||||
{ "Gimp_EXAMPLE", NULL, 0, 1, -1 }, /* Start on currently visible tags floating, not tiled */
|
|
||||||
{ "firefox_EXAMPLE", NULL, 1 << 8, 0, -1 }, /* Start on ONLY tag "9" */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* layout(s) */
|
|
||||||
static const Layout layouts[] = {
|
|
||||||
/* symbol arrange function */
|
|
||||||
{ "[]=", tile },
|
|
||||||
{ "><>", NULL }, /* no layout function means floating behavior */
|
|
||||||
{ "[M]", monocle },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* monitors */
|
|
||||||
/* NOTE: ALWAYS add a fallback rule, even if you are completely sure it won't be used */
|
|
||||||
static const MonitorRule monrules[] = {
|
|
||||||
/* name mfact nmaster scale layout rotate/reflect x y */
|
|
||||||
/* example of a HiDPI monitor: */
|
|
||||||
{ "DP-1", 0.5f, 1, 2, &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, -1, -1 },
|
|
||||||
/* defaults */
|
|
||||||
{ NULL, 0.55f, 1, 1, &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, -1, -1 },
|
|
||||||
};
|
|
||||||
|
|
||||||
/* keyboard */
|
|
||||||
static const struct xkb_rule_names xkb_rules = {
|
|
||||||
/* can specify fields: rules, model, layout, variant, options */
|
|
||||||
/* example:
|
|
||||||
.options = "ctrl:nocaps",
|
|
||||||
*/
|
|
||||||
.options = NULL,
|
|
||||||
.layout = "pt",
|
|
||||||
};
|
|
||||||
|
|
||||||
static const int repeat_rate = 25;
|
|
||||||
static const int repeat_delay = 600;
|
|
||||||
|
|
||||||
/* Trackpad */
|
|
||||||
static const int tap_to_click = 1;
|
|
||||||
static const int tap_and_drag = 1;
|
|
||||||
static const int drag_lock = 1;
|
|
||||||
static const int natural_scrolling = 0;
|
|
||||||
static const int disable_while_typing = 1;
|
|
||||||
static const int left_handed = 0;
|
|
||||||
static const int middle_button_emulation = 1;
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_SCROLL_NO_SCROLL
|
|
||||||
LIBINPUT_CONFIG_SCROLL_2FG
|
|
||||||
LIBINPUT_CONFIG_SCROLL_EDGE
|
|
||||||
LIBINPUT_CONFIG_SCROLL_ON_BUTTON_DOWN
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_scroll_method scroll_method = LIBINPUT_CONFIG_SCROLL_2FG;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_CLICK_METHOD_NONE
|
|
||||||
LIBINPUT_CONFIG_CLICK_METHOD_BUTTON_AREAS
|
|
||||||
LIBINPUT_CONFIG_CLICK_METHOD_CLICKFINGER
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_click_method click_method = LIBINPUT_CONFIG_CLICK_METHOD_BUTTON_AREAS;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_SEND_EVENTS_ENABLED
|
|
||||||
LIBINPUT_CONFIG_SEND_EVENTS_DISABLED
|
|
||||||
LIBINPUT_CONFIG_SEND_EVENTS_DISABLED_ON_EXTERNAL_MOUSE
|
|
||||||
*/
|
|
||||||
static const uint32_t send_events_mode = LIBINPUT_CONFIG_SEND_EVENTS_ENABLED;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_ACCEL_PROFILE_FLAT
|
|
||||||
LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_accel_profile accel_profile = LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE;
|
|
||||||
static const double accel_speed = 0.0;
|
|
||||||
|
|
||||||
/* You can choose between:
|
|
||||||
LIBINPUT_CONFIG_TAP_MAP_LRM -- 1/2/3 finger tap maps to left/right/middle
|
|
||||||
LIBINPUT_CONFIG_TAP_MAP_LMR -- 1/2/3 finger tap maps to left/middle/right
|
|
||||||
*/
|
|
||||||
static const enum libinput_config_tap_button_map button_map = LIBINPUT_CONFIG_TAP_MAP_LRM;
|
|
||||||
|
|
||||||
/* If you want to use the windows key for MODKEY, use WLR_MODIFIER_LOGO */
|
|
||||||
#define MODKEY WLR_MODIFIER_LOGO
|
|
||||||
|
|
||||||
#define TAGKEYS(KEY,SKEY,TAG) \
|
|
||||||
{ MODKEY, KEY, view, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|WLR_MODIFIER_CTRL, KEY, toggleview, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, SKEY, tag, {.ui = 1 << TAG} }, \
|
|
||||||
{ MODKEY|WLR_MODIFIER_CTRL|WLR_MODIFIER_SHIFT,SKEY,toggletag, {.ui = 1 << TAG} }
|
|
||||||
|
|
||||||
/* helper for spawning shell commands in the pre dwm-5.0 fashion */
|
|
||||||
#define SHCMD(cmd) { .v = (const char*[]){ "/bin/sh", "-c", cmd, NULL } }
|
|
||||||
|
|
||||||
/* commands */
|
|
||||||
static const char *termcmd[] = { "foot", NULL };
|
|
||||||
static const char *menucmd[] = { "wofi", "--show", "run", NULL };
|
|
||||||
static const char *lockcmd[] = { "swaylock", "-f", NULL };
|
|
||||||
|
|
||||||
static const Key keys[] = {
|
|
||||||
/* Note that Shift changes certain key codes: c -> C, 2 -> at, etc. */
|
|
||||||
/* modifier key function argument */
|
|
||||||
{ MODKEY, XKB_KEY_p, spawn, {.v = menucmd} },
|
|
||||||
{ MODKEY, XKB_KEY_Return, spawn, {.v = termcmd} },
|
|
||||||
{ MODKEY, XKB_KEY_q, spawn, {.v = lockcmd} },
|
|
||||||
{ MODKEY, XKB_KEY_b, togglebar, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_j, focusstack, {.i = +1} },
|
|
||||||
{ MODKEY, XKB_KEY_k, focusstack, {.i = -1} },
|
|
||||||
{ MODKEY, XKB_KEY_i, incnmaster, {.i = +1} },
|
|
||||||
{ MODKEY, XKB_KEY_d, incnmaster, {.i = -1} },
|
|
||||||
{ MODKEY, XKB_KEY_h, setmfact, {.f = -0.05f} },
|
|
||||||
{ MODKEY, XKB_KEY_l, setmfact, {.f = +0.05f} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_Return, zoom, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_Tab, view, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_g, togglegaps, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_c, killclient, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_t, setlayout, {.v = &layouts[0]} },
|
|
||||||
{ MODKEY, XKB_KEY_f, setlayout, {.v = &layouts[1]} },
|
|
||||||
{ MODKEY, XKB_KEY_m, setlayout, {.v = &layouts[2]} },
|
|
||||||
{ MODKEY, XKB_KEY_space, setlayout, {0} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_space, togglefloating, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_e, togglefullscreen, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_0, view, {.ui = ~0} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_parenright, tag, {.ui = ~0} },
|
|
||||||
{ MODKEY, XKB_KEY_comma, focusmon, {.i = WLR_DIRECTION_LEFT} },
|
|
||||||
{ MODKEY, XKB_KEY_period, focusmon, {.i = WLR_DIRECTION_RIGHT} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_less, tagmon, {.i = WLR_DIRECTION_LEFT} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_greater, tagmon, {.i = WLR_DIRECTION_RIGHT} },
|
|
||||||
TAGKEYS( XKB_KEY_1, XKB_KEY_exclam, 0),
|
|
||||||
TAGKEYS( XKB_KEY_2, XKB_KEY_at, 1),
|
|
||||||
TAGKEYS( XKB_KEY_3, XKB_KEY_numbersign, 2),
|
|
||||||
TAGKEYS( XKB_KEY_4, XKB_KEY_dollar, 3),
|
|
||||||
TAGKEYS( XKB_KEY_5, XKB_KEY_percent, 4),
|
|
||||||
TAGKEYS( XKB_KEY_6, XKB_KEY_asciicircum, 5),
|
|
||||||
TAGKEYS( XKB_KEY_7, XKB_KEY_ampersand, 6),
|
|
||||||
TAGKEYS( XKB_KEY_8, XKB_KEY_asterisk, 7),
|
|
||||||
TAGKEYS( XKB_KEY_9, XKB_KEY_parenleft, 8),
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_Q, quit, {0} },
|
|
||||||
|
|
||||||
/* Ctrl-Alt-Backspace and Ctrl-Alt-Fx used to be handled by X server */
|
|
||||||
{ WLR_MODIFIER_CTRL|WLR_MODIFIER_ALT,XKB_KEY_Terminate_Server, quit, {0} },
|
|
||||||
/* Ctrl-Alt-Fx is used to switch to another VT, if you don't know what a VT is
|
|
||||||
* do not remove them.
|
|
||||||
*/
|
|
||||||
#define CHVT(n) { WLR_MODIFIER_CTRL|WLR_MODIFIER_ALT,XKB_KEY_XF86Switch_VT_##n, chvt, {.ui = (n)} }
|
|
||||||
CHVT(1), CHVT(2), CHVT(3), CHVT(4), CHVT(5), CHVT(6),
|
|
||||||
CHVT(7), CHVT(8), CHVT(9), CHVT(10), CHVT(11), CHVT(12),
|
|
||||||
};
|
|
||||||
|
|
||||||
static const Button buttons[] = {
|
|
||||||
{ MODKEY, BTN_LEFT, moveresize, {.ui = CurMove} },
|
|
||||||
{ MODKEY, BTN_MIDDLE, togglefloating, {0} },
|
|
||||||
{ MODKEY, BTN_RIGHT, moveresize, {.ui = CurResize} },
|
|
||||||
};
|
|
||||||
@@ -1,15 +0,0 @@
|
|||||||
_VERSION = 0.5
|
|
||||||
VERSION = `git describe --tags --dirty 2>/dev/null || echo $(_VERSION)`
|
|
||||||
|
|
||||||
PKG_CONFIG = pkg-config
|
|
||||||
|
|
||||||
# paths
|
|
||||||
PREFIX = /usr/local
|
|
||||||
MANDIR = $(PREFIX)/share/man
|
|
||||||
DATADIR = $(PREFIX)/share
|
|
||||||
|
|
||||||
XWAYLAND =
|
|
||||||
XLIBS =
|
|
||||||
# Uncomment to build XWayland support
|
|
||||||
XWAYLAND = -DXWAYLAND
|
|
||||||
XLIBS = xcb xcb-icccm
|
|
||||||
@@ -1,365 +0,0 @@
|
|||||||
/* Generated by wayland-scanner 1.22.0 */
|
|
||||||
|
|
||||||
#ifndef CURSOR_SHAPE_V1_SERVER_PROTOCOL_H
|
|
||||||
#define CURSOR_SHAPE_V1_SERVER_PROTOCOL_H
|
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stddef.h>
|
|
||||||
#include "wayland-server.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct wl_client;
|
|
||||||
struct wl_resource;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @page page_cursor_shape_v1 The cursor_shape_v1 protocol
|
|
||||||
* @section page_ifaces_cursor_shape_v1 Interfaces
|
|
||||||
* - @subpage page_iface_wp_cursor_shape_manager_v1 - cursor shape manager
|
|
||||||
* - @subpage page_iface_wp_cursor_shape_device_v1 - cursor shape for a device
|
|
||||||
* @section page_copyright_cursor_shape_v1 Copyright
|
|
||||||
* <pre>
|
|
||||||
*
|
|
||||||
* Copyright 2018 The Chromium Authors
|
|
||||||
* Copyright 2023 Simon Ser
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
||||||
* copy of this software and associated documentation files (the "Software"),
|
|
||||||
* to deal in the Software without restriction, including without limitation
|
|
||||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
||||||
* and/or sell copies of the Software, and to permit persons to whom the
|
|
||||||
* Software is furnished to do so, subject to the following conditions:
|
|
||||||
* The above copyright notice and this permission notice (including the next
|
|
||||||
* paragraph) shall be included in all copies or substantial portions of the
|
|
||||||
* Software.
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
||||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
||||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
||||||
* DEALINGS IN THE SOFTWARE.
|
|
||||||
* </pre>
|
|
||||||
*/
|
|
||||||
struct wl_pointer;
|
|
||||||
struct wp_cursor_shape_device_v1;
|
|
||||||
struct wp_cursor_shape_manager_v1;
|
|
||||||
struct zwp_tablet_tool_v2;
|
|
||||||
|
|
||||||
#ifndef WP_CURSOR_SHAPE_MANAGER_V1_INTERFACE
|
|
||||||
#define WP_CURSOR_SHAPE_MANAGER_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_wp_cursor_shape_manager_v1 wp_cursor_shape_manager_v1
|
|
||||||
* @section page_iface_wp_cursor_shape_manager_v1_desc Description
|
|
||||||
*
|
|
||||||
* This global offers an alternative, optional way to set cursor images. This
|
|
||||||
* new way uses enumerated cursors instead of a wl_surface like
|
|
||||||
* wl_pointer.set_cursor does.
|
|
||||||
*
|
|
||||||
* Warning! The protocol described in this file is currently in the testing
|
|
||||||
* phase. Backward compatible changes may be added together with the
|
|
||||||
* corresponding interface version bump. Backward incompatible changes can
|
|
||||||
* only be done by creating a new major version of the extension.
|
|
||||||
* @section page_iface_wp_cursor_shape_manager_v1_api API
|
|
||||||
* See @ref iface_wp_cursor_shape_manager_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_wp_cursor_shape_manager_v1 The wp_cursor_shape_manager_v1 interface
|
|
||||||
*
|
|
||||||
* This global offers an alternative, optional way to set cursor images. This
|
|
||||||
* new way uses enumerated cursors instead of a wl_surface like
|
|
||||||
* wl_pointer.set_cursor does.
|
|
||||||
*
|
|
||||||
* Warning! The protocol described in this file is currently in the testing
|
|
||||||
* phase. Backward compatible changes may be added together with the
|
|
||||||
* corresponding interface version bump. Backward incompatible changes can
|
|
||||||
* only be done by creating a new major version of the extension.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface wp_cursor_shape_manager_v1_interface;
|
|
||||||
#endif
|
|
||||||
#ifndef WP_CURSOR_SHAPE_DEVICE_V1_INTERFACE
|
|
||||||
#define WP_CURSOR_SHAPE_DEVICE_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_wp_cursor_shape_device_v1 wp_cursor_shape_device_v1
|
|
||||||
* @section page_iface_wp_cursor_shape_device_v1_desc Description
|
|
||||||
*
|
|
||||||
* This interface allows clients to set the cursor shape.
|
|
||||||
* @section page_iface_wp_cursor_shape_device_v1_api API
|
|
||||||
* See @ref iface_wp_cursor_shape_device_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_wp_cursor_shape_device_v1 The wp_cursor_shape_device_v1 interface
|
|
||||||
*
|
|
||||||
* This interface allows clients to set the cursor shape.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface wp_cursor_shape_device_v1_interface;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_manager_v1
|
|
||||||
* @struct wp_cursor_shape_manager_v1_interface
|
|
||||||
*/
|
|
||||||
struct wp_cursor_shape_manager_v1_interface {
|
|
||||||
/**
|
|
||||||
* destroy the manager
|
|
||||||
*
|
|
||||||
* Destroy the cursor shape manager.
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* manage the cursor shape of a pointer device
|
|
||||||
*
|
|
||||||
* Obtain a wp_cursor_shape_device_v1 for a wl_pointer object.
|
|
||||||
*/
|
|
||||||
void (*get_pointer)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t cursor_shape_device,
|
|
||||||
struct wl_resource *pointer);
|
|
||||||
/**
|
|
||||||
* manage the cursor shape of a tablet tool device
|
|
||||||
*
|
|
||||||
* Obtain a wp_cursor_shape_device_v1 for a zwp_tablet_tool_v2
|
|
||||||
* object.
|
|
||||||
*/
|
|
||||||
void (*get_tablet_tool_v2)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t cursor_shape_device,
|
|
||||||
struct wl_resource *tablet_tool);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_manager_v1
|
|
||||||
*/
|
|
||||||
#define WP_CURSOR_SHAPE_MANAGER_V1_DESTROY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_manager_v1
|
|
||||||
*/
|
|
||||||
#define WP_CURSOR_SHAPE_MANAGER_V1_GET_POINTER_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_manager_v1
|
|
||||||
*/
|
|
||||||
#define WP_CURSOR_SHAPE_MANAGER_V1_GET_TABLET_TOOL_V2_SINCE_VERSION 1
|
|
||||||
|
|
||||||
#ifndef WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ENUM
|
|
||||||
#define WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ENUM
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_device_v1
|
|
||||||
* cursor shapes
|
|
||||||
*
|
|
||||||
* This enum describes cursor shapes.
|
|
||||||
*
|
|
||||||
* The names are taken from the CSS W3C specification:
|
|
||||||
* https://w3c.github.io/csswg-drafts/css-ui/#cursor
|
|
||||||
*/
|
|
||||||
enum wp_cursor_shape_device_v1_shape {
|
|
||||||
/**
|
|
||||||
* default cursor
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_DEFAULT = 1,
|
|
||||||
/**
|
|
||||||
* a context menu is available for the object under the cursor
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_CONTEXT_MENU = 2,
|
|
||||||
/**
|
|
||||||
* help is available for the object under the cursor
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_HELP = 3,
|
|
||||||
/**
|
|
||||||
* pointer that indicates a link or another interactive element
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_POINTER = 4,
|
|
||||||
/**
|
|
||||||
* progress indicator
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_PROGRESS = 5,
|
|
||||||
/**
|
|
||||||
* program is busy, user should wait
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_WAIT = 6,
|
|
||||||
/**
|
|
||||||
* a cell or set of cells may be selected
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_CELL = 7,
|
|
||||||
/**
|
|
||||||
* simple crosshair
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_CROSSHAIR = 8,
|
|
||||||
/**
|
|
||||||
* text may be selected
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_TEXT = 9,
|
|
||||||
/**
|
|
||||||
* vertical text may be selected
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_VERTICAL_TEXT = 10,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: alias of/shortcut to something is to be created
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ALIAS = 11,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: something is to be copied
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_COPY = 12,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: something is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_MOVE = 13,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: the dragged item cannot be dropped at the current cursor location
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NO_DROP = 14,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: the requested action will not be carried out
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NOT_ALLOWED = 15,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: something can be grabbed
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_GRAB = 16,
|
|
||||||
/**
|
|
||||||
* drag-and-drop: something is being grabbed
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_GRABBING = 17,
|
|
||||||
/**
|
|
||||||
* resizing: the east border is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_E_RESIZE = 18,
|
|
||||||
/**
|
|
||||||
* resizing: the north border is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_N_RESIZE = 19,
|
|
||||||
/**
|
|
||||||
* resizing: the north-east corner is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NE_RESIZE = 20,
|
|
||||||
/**
|
|
||||||
* resizing: the north-west corner is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NW_RESIZE = 21,
|
|
||||||
/**
|
|
||||||
* resizing: the south border is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_S_RESIZE = 22,
|
|
||||||
/**
|
|
||||||
* resizing: the south-east corner is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_SE_RESIZE = 23,
|
|
||||||
/**
|
|
||||||
* resizing: the south-west corner is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_SW_RESIZE = 24,
|
|
||||||
/**
|
|
||||||
* resizing: the west border is to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_W_RESIZE = 25,
|
|
||||||
/**
|
|
||||||
* resizing: the east and west borders are to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_EW_RESIZE = 26,
|
|
||||||
/**
|
|
||||||
* resizing: the north and south borders are to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NS_RESIZE = 27,
|
|
||||||
/**
|
|
||||||
* resizing: the north-east and south-west corners are to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NESW_RESIZE = 28,
|
|
||||||
/**
|
|
||||||
* resizing: the north-west and south-east corners are to be moved
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_NWSE_RESIZE = 29,
|
|
||||||
/**
|
|
||||||
* resizing: that the item/column can be resized horizontally
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_COL_RESIZE = 30,
|
|
||||||
/**
|
|
||||||
* resizing: that the item/row can be resized vertically
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ROW_RESIZE = 31,
|
|
||||||
/**
|
|
||||||
* something can be scrolled in any direction
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ALL_SCROLL = 32,
|
|
||||||
/**
|
|
||||||
* something can be zoomed in
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ZOOM_IN = 33,
|
|
||||||
/**
|
|
||||||
* something can be zoomed out
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ZOOM_OUT = 34,
|
|
||||||
};
|
|
||||||
#endif /* WP_CURSOR_SHAPE_DEVICE_V1_SHAPE_ENUM */
|
|
||||||
|
|
||||||
#ifndef WP_CURSOR_SHAPE_DEVICE_V1_ERROR_ENUM
|
|
||||||
#define WP_CURSOR_SHAPE_DEVICE_V1_ERROR_ENUM
|
|
||||||
enum wp_cursor_shape_device_v1_error {
|
|
||||||
/**
|
|
||||||
* the specified shape value is invalid
|
|
||||||
*/
|
|
||||||
WP_CURSOR_SHAPE_DEVICE_V1_ERROR_INVALID_SHAPE = 1,
|
|
||||||
};
|
|
||||||
#endif /* WP_CURSOR_SHAPE_DEVICE_V1_ERROR_ENUM */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_device_v1
|
|
||||||
* @struct wp_cursor_shape_device_v1_interface
|
|
||||||
*/
|
|
||||||
struct wp_cursor_shape_device_v1_interface {
|
|
||||||
/**
|
|
||||||
* destroy the cursor shape device
|
|
||||||
*
|
|
||||||
* Destroy the cursor shape device.
|
|
||||||
*
|
|
||||||
* The device cursor shape remains unchanged.
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* set device cursor to the shape
|
|
||||||
*
|
|
||||||
* Sets the device cursor to the specified shape. The compositor
|
|
||||||
* will change the cursor image based on the specified shape.
|
|
||||||
*
|
|
||||||
* The cursor actually changes only if the input device focus is
|
|
||||||
* one of the requesting client's surfaces. If any, the previous
|
|
||||||
* cursor image (surface or shape) is replaced.
|
|
||||||
*
|
|
||||||
* The "shape" argument must be a valid enum entry, otherwise the
|
|
||||||
* invalid_shape protocol error is raised.
|
|
||||||
*
|
|
||||||
* This is similar to the wl_pointer.set_cursor and
|
|
||||||
* zwp_tablet_tool_v2.set_cursor requests, but this request accepts
|
|
||||||
* a shape instead of contents in the form of a surface. Clients
|
|
||||||
* can mix set_cursor and set_shape requests.
|
|
||||||
*
|
|
||||||
* The serial parameter must match the latest wl_pointer.enter or
|
|
||||||
* zwp_tablet_tool_v2.proximity_in serial number sent to the
|
|
||||||
* client. Otherwise the request will be ignored.
|
|
||||||
* @param serial serial number of the enter event
|
|
||||||
*/
|
|
||||||
void (*set_shape)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t serial,
|
|
||||||
uint32_t shape);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_device_v1
|
|
||||||
*/
|
|
||||||
#define WP_CURSOR_SHAPE_DEVICE_V1_DESTROY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_wp_cursor_shape_device_v1
|
|
||||||
*/
|
|
||||||
#define WP_CURSOR_SHAPE_DEVICE_V1_SET_SHAPE_SINCE_VERSION 1
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
@@ -1,70 +0,0 @@
|
|||||||
/* Generated by wayland-scanner 1.22.0 */
|
|
||||||
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <stdint.h>
|
|
||||||
#include "wayland-util.h"
|
|
||||||
|
|
||||||
#ifndef __has_attribute
|
|
||||||
# define __has_attribute(x) 0 /* Compatibility with non-clang compilers. */
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if (__has_attribute(visibility) || defined(__GNUC__) && __GNUC__ >= 4)
|
|
||||||
#define WL_PRIVATE __attribute__ ((visibility("hidden")))
|
|
||||||
#else
|
|
||||||
#define WL_PRIVATE
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern const struct wl_interface wl_output_interface;
|
|
||||||
extern const struct wl_interface zdwl_ipc_output_v2_interface;
|
|
||||||
|
|
||||||
static const struct wl_interface *dwl_ipc_unstable_v2_types[] = {
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
NULL,
|
|
||||||
&zdwl_ipc_output_v2_interface,
|
|
||||||
&wl_output_interface,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct wl_message zdwl_ipc_manager_v2_requests[] = {
|
|
||||||
{ "release", "", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "get_output", "no", dwl_ipc_unstable_v2_types + 4 },
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct wl_message zdwl_ipc_manager_v2_events[] = {
|
|
||||||
{ "tags", "u", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "layout", "s", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
};
|
|
||||||
|
|
||||||
WL_PRIVATE const struct wl_interface zdwl_ipc_manager_v2_interface = {
|
|
||||||
"zdwl_ipc_manager_v2", 2,
|
|
||||||
2, zdwl_ipc_manager_v2_requests,
|
|
||||||
2, zdwl_ipc_manager_v2_events,
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct wl_message zdwl_ipc_output_v2_requests[] = {
|
|
||||||
{ "release", "", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "set_tags", "uu", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "set_client_tags", "uu", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "set_layout", "u", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
};
|
|
||||||
|
|
||||||
static const struct wl_message zdwl_ipc_output_v2_events[] = {
|
|
||||||
{ "toggle_visibility", "", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "active", "u", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "tag", "uuuu", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "layout", "u", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "title", "s", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "appid", "s", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "layout_symbol", "s", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "frame", "", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "fullscreen", "2u", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
{ "floating", "2u", dwl_ipc_unstable_v2_types + 0 },
|
|
||||||
};
|
|
||||||
|
|
||||||
WL_PRIVATE const struct wl_interface zdwl_ipc_output_v2_interface = {
|
|
||||||
"zdwl_ipc_output_v2", 2,
|
|
||||||
4, zdwl_ipc_output_v2_requests,
|
|
||||||
10, zdwl_ipc_output_v2_events,
|
|
||||||
};
|
|
||||||
|
|
||||||
@@ -1,422 +0,0 @@
|
|||||||
/* Generated by wayland-scanner 1.22.0 */
|
|
||||||
|
|
||||||
#ifndef DWL_IPC_UNSTABLE_V2_SERVER_PROTOCOL_H
|
|
||||||
#define DWL_IPC_UNSTABLE_V2_SERVER_PROTOCOL_H
|
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stddef.h>
|
|
||||||
#include "wayland-server.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct wl_client;
|
|
||||||
struct wl_resource;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @page page_dwl_ipc_unstable_v2 The dwl_ipc_unstable_v2 protocol
|
|
||||||
* inter-proccess-communication about dwl's state
|
|
||||||
*
|
|
||||||
* @section page_desc_dwl_ipc_unstable_v2 Description
|
|
||||||
*
|
|
||||||
* This protocol allows clients to update and get updates from dwl.
|
|
||||||
*
|
|
||||||
* Warning! The protocol described in this file is experimental and
|
|
||||||
* backward incompatible changes may be made. Backward compatible
|
|
||||||
* changes may be added together with the corresponding interface
|
|
||||||
* version bump.
|
|
||||||
* Backward incompatible changes are done by bumping the version
|
|
||||||
* number in the protocol and interface names and resetting the
|
|
||||||
* interface version. Once the protocol is to be declared stable,
|
|
||||||
* the 'z' prefix and the version number in the protocol and
|
|
||||||
* interface names are removed and the interface version number is
|
|
||||||
* reset.
|
|
||||||
*
|
|
||||||
* @section page_ifaces_dwl_ipc_unstable_v2 Interfaces
|
|
||||||
* - @subpage page_iface_zdwl_ipc_manager_v2 - manage dwl state
|
|
||||||
* - @subpage page_iface_zdwl_ipc_output_v2 - control dwl output
|
|
||||||
*/
|
|
||||||
struct wl_output;
|
|
||||||
struct zdwl_ipc_manager_v2;
|
|
||||||
struct zdwl_ipc_output_v2;
|
|
||||||
|
|
||||||
#ifndef ZDWL_IPC_MANAGER_V2_INTERFACE
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zdwl_ipc_manager_v2 zdwl_ipc_manager_v2
|
|
||||||
* @section page_iface_zdwl_ipc_manager_v2_desc Description
|
|
||||||
*
|
|
||||||
* This interface is exposed as a global in wl_registry.
|
|
||||||
*
|
|
||||||
* Clients can use this interface to get a dwl_ipc_output.
|
|
||||||
* After binding the client will recieve the dwl_ipc_manager.tags and dwl_ipc_manager.layout events.
|
|
||||||
* The dwl_ipc_manager.tags and dwl_ipc_manager.layout events expose tags and layouts to the client.
|
|
||||||
* @section page_iface_zdwl_ipc_manager_v2_api API
|
|
||||||
* See @ref iface_zdwl_ipc_manager_v2.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zdwl_ipc_manager_v2 The zdwl_ipc_manager_v2 interface
|
|
||||||
*
|
|
||||||
* This interface is exposed as a global in wl_registry.
|
|
||||||
*
|
|
||||||
* Clients can use this interface to get a dwl_ipc_output.
|
|
||||||
* After binding the client will recieve the dwl_ipc_manager.tags and dwl_ipc_manager.layout events.
|
|
||||||
* The dwl_ipc_manager.tags and dwl_ipc_manager.layout events expose tags and layouts to the client.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zdwl_ipc_manager_v2_interface;
|
|
||||||
#endif
|
|
||||||
#ifndef ZDWL_IPC_OUTPUT_V2_INTERFACE
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zdwl_ipc_output_v2 zdwl_ipc_output_v2
|
|
||||||
* @section page_iface_zdwl_ipc_output_v2_desc Description
|
|
||||||
*
|
|
||||||
* Observe and control a dwl output.
|
|
||||||
*
|
|
||||||
* Events are double-buffered:
|
|
||||||
* Clients should cache events and redraw when a dwl_ipc_output.frame event is sent.
|
|
||||||
*
|
|
||||||
* Request are not double-buffered:
|
|
||||||
* The compositor will update immediately upon request.
|
|
||||||
* @section page_iface_zdwl_ipc_output_v2_api API
|
|
||||||
* See @ref iface_zdwl_ipc_output_v2.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zdwl_ipc_output_v2 The zdwl_ipc_output_v2 interface
|
|
||||||
*
|
|
||||||
* Observe and control a dwl output.
|
|
||||||
*
|
|
||||||
* Events are double-buffered:
|
|
||||||
* Clients should cache events and redraw when a dwl_ipc_output.frame event is sent.
|
|
||||||
*
|
|
||||||
* Request are not double-buffered:
|
|
||||||
* The compositor will update immediately upon request.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zdwl_ipc_output_v2_interface;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
* @struct zdwl_ipc_manager_v2_interface
|
|
||||||
*/
|
|
||||||
struct zdwl_ipc_manager_v2_interface {
|
|
||||||
/**
|
|
||||||
* release dwl_ipc_manager
|
|
||||||
*
|
|
||||||
* Indicates that the client will not the dwl_ipc_manager object
|
|
||||||
* anymore. Objects created through this instance are not affected.
|
|
||||||
*/
|
|
||||||
void (*release)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* get a dwl_ipc_outout for a wl_output
|
|
||||||
*
|
|
||||||
* Get a dwl_ipc_outout for the specified wl_output.
|
|
||||||
*/
|
|
||||||
void (*get_output)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t id,
|
|
||||||
struct wl_resource *output);
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_TAGS 0
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_LAYOUT 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_TAGS_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_LAYOUT_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_RELEASE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_MANAGER_V2_GET_OUTPUT_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
* Sends an tags event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_manager_v2_send_tags(struct wl_resource *resource_, uint32_t amount)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_MANAGER_V2_TAGS, amount);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_manager_v2
|
|
||||||
* Sends an layout event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_manager_v2_send_layout(struct wl_resource *resource_, const char *name)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_MANAGER_V2_LAYOUT, name);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifndef ZDWL_IPC_OUTPUT_V2_TAG_STATE_ENUM
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TAG_STATE_ENUM
|
|
||||||
enum zdwl_ipc_output_v2_tag_state {
|
|
||||||
/**
|
|
||||||
* no state
|
|
||||||
*/
|
|
||||||
ZDWL_IPC_OUTPUT_V2_TAG_STATE_NONE = 0,
|
|
||||||
/**
|
|
||||||
* tag is active
|
|
||||||
*/
|
|
||||||
ZDWL_IPC_OUTPUT_V2_TAG_STATE_ACTIVE = 1,
|
|
||||||
/**
|
|
||||||
* tag has at least one urgent client
|
|
||||||
*/
|
|
||||||
ZDWL_IPC_OUTPUT_V2_TAG_STATE_URGENT = 2,
|
|
||||||
};
|
|
||||||
#endif /* ZDWL_IPC_OUTPUT_V2_TAG_STATE_ENUM */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* @struct zdwl_ipc_output_v2_interface
|
|
||||||
*/
|
|
||||||
struct zdwl_ipc_output_v2_interface {
|
|
||||||
/**
|
|
||||||
* release dwl_ipc_outout
|
|
||||||
*
|
|
||||||
* Indicates to that the client no longer needs this
|
|
||||||
* dwl_ipc_output.
|
|
||||||
*/
|
|
||||||
void (*release)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* Set the active tags of this output
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param tagmask bitmask of the tags that should be set.
|
|
||||||
* @param toggle_tagset toggle the selected tagset, zero for invalid, nonzero for valid.
|
|
||||||
*/
|
|
||||||
void (*set_tags)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t tagmask,
|
|
||||||
uint32_t toggle_tagset);
|
|
||||||
/**
|
|
||||||
* Set the tags of the focused client.
|
|
||||||
*
|
|
||||||
* The tags are updated as follows: new_tags = (current_tags AND
|
|
||||||
* and_tags) XOR xor_tags
|
|
||||||
*/
|
|
||||||
void (*set_client_tags)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t and_tags,
|
|
||||||
uint32_t xor_tags);
|
|
||||||
/**
|
|
||||||
* Set the layout of this output
|
|
||||||
*
|
|
||||||
*
|
|
||||||
* @param index index of a layout recieved by dwl_ipc_manager.layout
|
|
||||||
*/
|
|
||||||
void (*set_layout)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t index);
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TOGGLE_VISIBILITY 0
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_ACTIVE 1
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TAG 2
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_LAYOUT 3
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TITLE 4
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_APPID 5
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_LAYOUT_SYMBOL 6
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_FRAME 7
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_FULLSCREEN 8
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_FLOATING 9
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TOGGLE_VISIBILITY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_ACTIVE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TAG_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_LAYOUT_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_TITLE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_APPID_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_LAYOUT_SYMBOL_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_FRAME_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_FULLSCREEN_SINCE_VERSION 2
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_FLOATING_SINCE_VERSION 2
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_RELEASE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_SET_TAGS_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_SET_CLIENT_TAGS_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
*/
|
|
||||||
#define ZDWL_IPC_OUTPUT_V2_SET_LAYOUT_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an toggle_visibility event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_toggle_visibility(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_TOGGLE_VISIBILITY);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an active event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_active(struct wl_resource *resource_, uint32_t active)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_ACTIVE, active);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an tag event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param tag Index of the tag
|
|
||||||
* @param state The state of the tag.
|
|
||||||
* @param clients The number of clients in the tag.
|
|
||||||
* @param focused If there is a focused client. Nonzero being valid, zero being invalid.
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_tag(struct wl_resource *resource_, uint32_t tag, uint32_t state, uint32_t clients, uint32_t focused)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_TAG, tag, state, clients, focused);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an layout event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param layout Index of the layout.
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_layout(struct wl_resource *resource_, uint32_t layout)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_LAYOUT, layout);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an title event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param title The new title name.
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_title(struct wl_resource *resource_, const char *title)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_TITLE, title);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an appid event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param appid The new appid.
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_appid(struct wl_resource *resource_, const char *appid)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_APPID, appid);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an layout_symbol event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param layout The new layout
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_layout_symbol(struct wl_resource *resource_, const char *layout)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_LAYOUT_SYMBOL, layout);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an frame event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_frame(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_FRAME);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an fullscreen event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param is_fullscreen If the selected client is fullscreen. Nonzero is valid, zero invalid
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_fullscreen(struct wl_resource *resource_, uint32_t is_fullscreen)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_FULLSCREEN, is_fullscreen);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zdwl_ipc_output_v2
|
|
||||||
* Sends an floating event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
* @param is_floating If the selected client is floating. Nonzero is valid, zero invalid
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zdwl_ipc_output_v2_send_floating(struct wl_resource *resource_, uint32_t is_floating)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZDWL_IPC_OUTPUT_V2_FLOATING, is_floating);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
158
dwl/dwl.1
158
dwl/dwl.1
@@ -1,158 +0,0 @@
|
|||||||
.Dd January 8, 2021
|
|
||||||
.Dt DWL 1
|
|
||||||
.Os
|
|
||||||
.Sh NAME
|
|
||||||
.Nm dwl
|
|
||||||
.Nd dwm for Wayland
|
|
||||||
.Sh SYNOPSIS
|
|
||||||
.Nm
|
|
||||||
.Op Fl v
|
|
||||||
.Op Fl d
|
|
||||||
.Op Fl s Ar startup command
|
|
||||||
.Sh DESCRIPTION
|
|
||||||
.Nm
|
|
||||||
is a Wayland compositor based on wlroots.
|
|
||||||
It is intended to fill the same space in the Wayland world that
|
|
||||||
.Nm dwm
|
|
||||||
does for X11.
|
|
||||||
.Pp
|
|
||||||
When given the
|
|
||||||
.Fl v
|
|
||||||
option,
|
|
||||||
.Nm
|
|
||||||
writes its name and version to standard error and exits unsuccessfully.
|
|
||||||
.Pp
|
|
||||||
When given the
|
|
||||||
.Fl d
|
|
||||||
option,
|
|
||||||
.Nm
|
|
||||||
enables full wlroots logging, including debug information.
|
|
||||||
.Pp
|
|
||||||
When given the
|
|
||||||
.Fl s
|
|
||||||
option,
|
|
||||||
.Nm
|
|
||||||
starts a shell process running
|
|
||||||
.Ar command
|
|
||||||
when starting.
|
|
||||||
When stopping, it sends
|
|
||||||
.Dv SIGTERM
|
|
||||||
to the child process and waits for it to exit.
|
|
||||||
.Pp
|
|
||||||
Users are encouraged to customize
|
|
||||||
.Nm
|
|
||||||
by editing the sources, in particular
|
|
||||||
.Pa config.h .
|
|
||||||
The default key bindings are as follows:
|
|
||||||
.Bl -tag -width 20n -offset indent -compact
|
|
||||||
.It Mod-[1-9]
|
|
||||||
Show only all windows with a tag.
|
|
||||||
.It Mod-Ctrl-[1-9]
|
|
||||||
Show all windows with a tag.
|
|
||||||
.It Mod-Shift-[1-9]
|
|
||||||
Move window to a single tag.
|
|
||||||
.It Mod-Ctrl-Shift-[1-9]
|
|
||||||
Toggle tag for window.
|
|
||||||
.It Mod-p
|
|
||||||
Spawn
|
|
||||||
.Nm wmenu-run .
|
|
||||||
.It Mod-Shift-Return
|
|
||||||
Spawn
|
|
||||||
.Nm foot .
|
|
||||||
.It Mod-[jk]
|
|
||||||
Move focus down/up the stack.
|
|
||||||
.It Mod-[id]
|
|
||||||
Increase/decrease number of windows in master area.
|
|
||||||
.It Mod-[hl]
|
|
||||||
Decrease/increase master area.
|
|
||||||
.It Mod-Return
|
|
||||||
Move window on top of stack or switch top of stack with second window.
|
|
||||||
.It Mod-Tab
|
|
||||||
Show only all windows with previous tag.
|
|
||||||
.It Mod-Shift-c
|
|
||||||
Close window.
|
|
||||||
.It Mod-t
|
|
||||||
Switch to tabbed layout.
|
|
||||||
.It Mod-f
|
|
||||||
Switch to floating layout.
|
|
||||||
.It Mod-m
|
|
||||||
Switch to monocle layout.
|
|
||||||
.It Mod-Space
|
|
||||||
Switch to previous layout.
|
|
||||||
.It Mod-Shift-Space
|
|
||||||
Toggle floating state of window.
|
|
||||||
.It Mod-e
|
|
||||||
Toggle fullscreen state of window.
|
|
||||||
.It Mod-0
|
|
||||||
Show all windows.
|
|
||||||
.It Mod-Shift-0
|
|
||||||
Set all tags for window.
|
|
||||||
.It Mod-,
|
|
||||||
Move focus to previous monitor.
|
|
||||||
.It Mod-.
|
|
||||||
Move focus to next monitor.
|
|
||||||
.It Mod-Shift-,
|
|
||||||
Move window to previous monitor.
|
|
||||||
.It Mod-Shift-.
|
|
||||||
Move window to next monitor.
|
|
||||||
.It Mod-Shift-q
|
|
||||||
Quit
|
|
||||||
.Nm .
|
|
||||||
.El
|
|
||||||
These might differ depending on your keyboard layout.
|
|
||||||
.Sh ENVIRONMENT
|
|
||||||
These environment variables are used by
|
|
||||||
.Nm :
|
|
||||||
.Bl -tag -width XDG_RUNTIME_DIR
|
|
||||||
.It Ev XDG_RUNTIME_DIR
|
|
||||||
A directory where temporary user files, such as the Wayland socket,
|
|
||||||
are stored.
|
|
||||||
.It Ev XDG_CONFIG_DIR
|
|
||||||
A directory containing configuration of various programs and
|
|
||||||
libraries, including libxkbcommon.
|
|
||||||
.It Ev DISPLAY , WAYLAND_DISPLAY , WAYLAND_SOCKET
|
|
||||||
Tell how to connect to an underlying X11 or Wayland server.
|
|
||||||
.It Ev WLR_*
|
|
||||||
Various variables specific to wlroots.
|
|
||||||
.It Ev XKB_* , XLOCALEDIR , XCOMPOSEFILE
|
|
||||||
Various variables specific to libxkbcommon.
|
|
||||||
.It Ev XCURSOR_PATH
|
|
||||||
List of directories to search for XCursor themes in.
|
|
||||||
.It Ev HOME
|
|
||||||
A directory where there are always dear files there for you.
|
|
||||||
Waiting for you to clean them up.
|
|
||||||
.El
|
|
||||||
.Pp
|
|
||||||
These are set by
|
|
||||||
.Nm :
|
|
||||||
.Bl -tag -width WAYLAND_DISPLAY
|
|
||||||
.It Ev WAYLAND_DISPLAY
|
|
||||||
Tell how to connect to
|
|
||||||
.Nm .
|
|
||||||
.It Ev DISPLAY
|
|
||||||
If using
|
|
||||||
.Nm Xwayland ,
|
|
||||||
tell how to connect to the
|
|
||||||
.Nm Xwayland
|
|
||||||
server.
|
|
||||||
.El
|
|
||||||
.Sh EXAMPLES
|
|
||||||
Start
|
|
||||||
.Nm
|
|
||||||
with s6 in the background:
|
|
||||||
.Dl dwl -s 's6-svscan <&-'
|
|
||||||
.Sh SEE ALSO
|
|
||||||
.Xr foot 1 ,
|
|
||||||
.Xr wmenu 1 ,
|
|
||||||
.Xr dwm 1 ,
|
|
||||||
.Xr xkeyboard-config 7
|
|
||||||
.Sh CAVEATS
|
|
||||||
The child process's standard input is connected with a pipe to
|
|
||||||
.Nm .
|
|
||||||
If the child process neither reads from the pipe nor closes its
|
|
||||||
standard input,
|
|
||||||
.Nm
|
|
||||||
will freeze after a while due to it blocking when writing to the full
|
|
||||||
pipe buffer.
|
|
||||||
.Sh BUGS
|
|
||||||
All of them.
|
|
||||||
@@ -1,5 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Name=dwl
|
|
||||||
Comment=dwm for Wayland
|
|
||||||
Exec=dwl
|
|
||||||
Type=Application
|
|
||||||
@@ -1,154 +0,0 @@
|
|||||||
From 51d56a433f23e13ac711b283a03c7903068febf6 Mon Sep 17 00:00:00 2001
|
|
||||||
From: =?UTF-8?q?Leonardo=20Hern=C3=A1ndez=20Hern=C3=A1ndez?=
|
|
||||||
<leohdz172@proton.me>
|
|
||||||
Date: Sat, 8 Jul 2023 17:11:36 -0600
|
|
||||||
Subject: [PATCH] port autostart patch from dwm
|
|
||||||
MIME-Version: 1.0
|
|
||||||
Content-Type: text/plain; charset=UTF-8
|
|
||||||
Content-Transfer-Encoding: 8bit
|
|
||||||
|
|
||||||
https://dwm.suckless.org/patches/cool_autostart/
|
|
||||||
Signed-off-by: Leonardo Hernández Hernández <leohdz172@proton.me>
|
|
||||||
---
|
|
||||||
config.def.h | 7 +++++++
|
|
||||||
dwl.c | 59 +++++++++++++++++++++++++++++++++++++++++++++++-----
|
|
||||||
2 files changed, 61 insertions(+), 5 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/config.def.h b/config.def.h
|
|
||||||
index a8ed61d..3585711 100644
|
|
||||||
--- a/config.def.h
|
|
||||||
+++ b/config.def.h
|
|
||||||
@@ -20,6 +20,13 @@ static const float fullscreen_bg[] = {0.1, 0.1, 0.1, 1.0}; /* You can al
|
|
||||||
/* logging */
|
|
||||||
static int log_level = WLR_ERROR;
|
|
||||||
|
|
||||||
+/* Autostart */
|
|
||||||
+static const char *const autostart[] = {
|
|
||||||
+ "wbg", "/path/to/your/image", NULL,
|
|
||||||
+ NULL /* terminate */
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
+
|
|
||||||
static const Rule rules[] = {
|
|
||||||
/* app_id title tags mask isfloating monitor */
|
|
||||||
/* examples:
|
|
||||||
diff --git a/dwl.c b/dwl.c
|
|
||||||
index 10d5a5b..bbbef2b 100644
|
|
||||||
--- a/dwl.c
|
|
||||||
+++ b/dwl.c
|
|
||||||
@@ -236,6 +236,7 @@ static void arrange(Monitor *m);
|
|
||||||
static void arrangelayer(Monitor *m, struct wl_list *list,
|
|
||||||
struct wlr_box *usable_area, int exclusive);
|
|
||||||
static void arrangelayers(Monitor *m);
|
|
||||||
+static void autostartexec(void);
|
|
||||||
static void axisnotify(struct wl_listener *listener, void *data);
|
|
||||||
static void buttonpress(struct wl_listener *listener, void *data);
|
|
||||||
static void chvt(const Arg *arg);
|
|
||||||
@@ -403,6 +404,9 @@ static xcb_atom_t netatom[NetLast];
|
|
||||||
/* attempt to encapsulate suck into one file */
|
|
||||||
#include "client.h"
|
|
||||||
|
|
||||||
+static pid_t *autostart_pids;
|
|
||||||
+static size_t autostart_len;
|
|
||||||
+
|
|
||||||
/* function implementations */
|
|
||||||
void
|
|
||||||
applybounds(Client *c, struct wlr_box *bbox)
|
|
||||||
@@ -533,6 +537,27 @@ arrangelayers(Monitor *m)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
+void
|
|
||||||
+autostartexec(void) {
|
|
||||||
+ const char *const *p;
|
|
||||||
+ size_t i = 0;
|
|
||||||
+
|
|
||||||
+ /* count entries */
|
|
||||||
+ for (p = autostart; *p; autostart_len++, p++)
|
|
||||||
+ while (*++p);
|
|
||||||
+
|
|
||||||
+ autostart_pids = calloc(autostart_len, sizeof(pid_t));
|
|
||||||
+ for (p = autostart; *p; i++, p++) {
|
|
||||||
+ if ((autostart_pids[i] = fork()) == 0) {
|
|
||||||
+ setsid();
|
|
||||||
+ execvp(*p, (char *const *)p);
|
|
||||||
+ die("dwl: execvp %s:", *p);
|
|
||||||
+ }
|
|
||||||
+ /* skip arguments */
|
|
||||||
+ while (*++p);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
void
|
|
||||||
axisnotify(struct wl_listener *listener, void *data)
|
|
||||||
{
|
|
||||||
@@ -630,11 +655,21 @@ checkidleinhibitor(struct wlr_surface *exclude)
|
|
||||||
void
|
|
||||||
cleanup(void)
|
|
||||||
{
|
|
||||||
+ size_t i;
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
wlr_xwayland_destroy(xwayland);
|
|
||||||
xwayland = NULL;
|
|
||||||
#endif
|
|
||||||
wl_display_destroy_clients(dpy);
|
|
||||||
+
|
|
||||||
+ /* kill child processes */
|
|
||||||
+ for (i = 0; i < autostart_len; i++) {
|
|
||||||
+ if (0 < autostart_pids[i]) {
|
|
||||||
+ kill(autostart_pids[i], SIGTERM);
|
|
||||||
+ waitpid(autostart_pids[i], NULL, 0);
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
if (child_pid > 0) {
|
|
||||||
kill(child_pid, SIGTERM);
|
|
||||||
waitpid(child_pid, NULL, 0);
|
|
||||||
@@ -1294,18 +1329,31 @@ void
|
|
||||||
handlesig(int signo)
|
|
||||||
{
|
|
||||||
if (signo == SIGCHLD) {
|
|
||||||
-#ifdef XWAYLAND
|
|
||||||
siginfo_t in;
|
|
||||||
/* wlroots expects to reap the XWayland process itself, so we
|
|
||||||
* use WNOWAIT to keep the child waitable until we know it's not
|
|
||||||
* XWayland.
|
|
||||||
*/
|
|
||||||
while (!waitid(P_ALL, 0, &in, WEXITED|WNOHANG|WNOWAIT) && in.si_pid
|
|
||||||
- && (!xwayland || in.si_pid != xwayland->server->pid))
|
|
||||||
- waitpid(in.si_pid, NULL, 0);
|
|
||||||
-#else
|
|
||||||
- while (waitpid(-1, NULL, WNOHANG) > 0);
|
|
||||||
+#ifdef XWAYLAND
|
|
||||||
+ && (!xwayland || in.si_pid != xwayland->server->pid)
|
|
||||||
#endif
|
|
||||||
+ ) {
|
|
||||||
+ pid_t *p, *lim;
|
|
||||||
+ waitpid(in.si_pid, NULL, 0);
|
|
||||||
+ if (in.si_pid == child_pid)
|
|
||||||
+ child_pid = -1;
|
|
||||||
+ if (!(p = autostart_pids))
|
|
||||||
+ continue;
|
|
||||||
+ lim = &p[autostart_len];
|
|
||||||
+
|
|
||||||
+ for (; p < lim; p++) {
|
|
||||||
+ if (*p == in.si_pid) {
|
|
||||||
+ *p = -1;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
} else if (signo == SIGINT || signo == SIGTERM) {
|
|
||||||
quit(NULL);
|
|
||||||
}
|
|
||||||
@@ -1965,6 +2013,7 @@ run(char *startup_cmd)
|
|
||||||
die("startup: backend_start");
|
|
||||||
|
|
||||||
/* Now that the socket exists and the backend is started, run the startup command */
|
|
||||||
+ autostartexec();
|
|
||||||
if (startup_cmd) {
|
|
||||||
int piperw[2];
|
|
||||||
if (pipe(piperw) < 0)
|
|
||||||
--
|
|
||||||
2.43.0
|
|
||||||
|
|
||||||
@@ -1,128 +0,0 @@
|
|||||||
From c814a3f16995a2fe8542c5bbdb28e38e7de5ef7e Mon Sep 17 00:00:00 2001
|
|
||||||
From: sewn <sewn@disroot.org>
|
|
||||||
Date: Sun, 15 Oct 2023 09:38:16 +0100
|
|
||||||
Subject: [PATCH] introduce gaps with functionality of useless gaps from dwm
|
|
||||||
|
|
||||||
Co-authored-by: serenevoid <ajuph9224@gmail.com>
|
|
||||||
---
|
|
||||||
config.def.h | 4 ++++
|
|
||||||
dwl.c | 38 ++++++++++++++++++++++++++++----------
|
|
||||||
2 files changed, 32 insertions(+), 10 deletions(-)
|
|
||||||
|
|
||||||
diff --git a/config.def.h b/config.def.h
|
|
||||||
index 8847e58..dca0a46 100644
|
|
||||||
--- a/config.def.h
|
|
||||||
+++ b/config.def.h
|
|
||||||
@@ -6,6 +6,9 @@
|
|
||||||
/* appearance */
|
|
||||||
static const int sloppyfocus = 1; /* focus follows mouse */
|
|
||||||
static const int bypass_surface_visibility = 0; /* 1 means idle inhibitors will disable idle tracking even if it's surface isn't visible */
|
|
||||||
+static const int smartgaps = 0; /* 1 means no outer gap when there is only one window */
|
|
||||||
+static int gaps = 1; /* 1 means gaps between windows are added */
|
|
||||||
+static const unsigned int gappx = 10; /* gap pixel between windows */
|
|
||||||
static const unsigned int borderpx = 1; /* border pixel of windows */
|
|
||||||
static const float rootcolor[] = COLOR(0x222222ff);
|
|
||||||
static const float bordercolor[] = COLOR(0x444444ff);
|
|
||||||
@@ -130,6 +133,7 @@ static const Key keys[] = {
|
|
||||||
{ MODKEY, XKB_KEY_l, setmfact, {.f = +0.05f} },
|
|
||||||
{ MODKEY, XKB_KEY_Return, zoom, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_Tab, view, {0} },
|
|
||||||
+ { MODKEY, XKB_KEY_g, togglegaps, {0} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_C, killclient, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_t, setlayout, {.v = &layouts[0]} },
|
|
||||||
{ MODKEY, XKB_KEY_f, setlayout, {.v = &layouts[1]} },
|
|
||||||
diff --git a/dwl.c b/dwl.c
|
|
||||||
index 39ce68c..2d317c5 100644
|
|
||||||
--- a/dwl.c
|
|
||||||
+++ b/dwl.c
|
|
||||||
@@ -198,6 +198,7 @@ struct Monitor {
|
|
||||||
struct wlr_box w; /* window area, layout-relative */
|
|
||||||
struct wl_list layers[4]; /* LayerSurface.link */
|
|
||||||
const Layout *lt[2];
|
|
||||||
+ int gaps;
|
|
||||||
unsigned int seltags;
|
|
||||||
unsigned int sellt;
|
|
||||||
uint32_t tagset[2];
|
|
||||||
@@ -332,6 +333,7 @@ static void tagmon(const Arg *arg);
|
|
||||||
static void tile(Monitor *m);
|
|
||||||
static void togglefloating(const Arg *arg);
|
|
||||||
static void togglefullscreen(const Arg *arg);
|
|
||||||
+static void togglegaps(const Arg *arg);
|
|
||||||
static void toggletag(const Arg *arg);
|
|
||||||
static void toggleview(const Arg *arg);
|
|
||||||
static void unlocksession(struct wl_listener *listener, void *data);
|
|
||||||
@@ -881,6 +883,8 @@ createmon(struct wl_listener *listener, void *data)
|
|
||||||
|
|
||||||
wlr_output_state_init(&state);
|
|
||||||
/* Initialize monitor state using configured rules */
|
|
||||||
+ m->gaps = gaps;
|
|
||||||
+
|
|
||||||
m->tagset[0] = m->tagset[1] = 1;
|
|
||||||
for (r = monrules; r < END(monrules); r++) {
|
|
||||||
if (!r->name || strstr(wlr_output->name, r->name)) {
|
|
||||||
@@ -2572,7 +2576,7 @@ tagmon(const Arg *arg)
|
|
||||||
void
|
|
||||||
tile(Monitor *m)
|
|
||||||
{
|
|
||||||
- unsigned int mw, my, ty;
|
|
||||||
+ unsigned int h, r, e = m->gaps, mw, my, ty;
|
|
||||||
int i, n = 0;
|
|
||||||
Client *c;
|
|
||||||
|
|
||||||
@@ -2581,23 +2585,30 @@ tile(Monitor *m)
|
|
||||||
n++;
|
|
||||||
if (n == 0)
|
|
||||||
return;
|
|
||||||
+ if (smartgaps == n)
|
|
||||||
+ e = 0;
|
|
||||||
|
|
||||||
if (n > m->nmaster)
|
|
||||||
- mw = m->nmaster ? ROUND(m->w.width * m->mfact) : 0;
|
|
||||||
+ mw = m->nmaster ? ROUND((m->w.width + gappx*e) * m->mfact) : 0;
|
|
||||||
else
|
|
||||||
- mw = m->w.width;
|
|
||||||
- i = my = ty = 0;
|
|
||||||
+ mw = m->w.width - 2*gappx*e + gappx*e;
|
|
||||||
+ i = 0;
|
|
||||||
+ my = ty = gappx*e;
|
|
||||||
wl_list_for_each(c, &clients, link) {
|
|
||||||
if (!VISIBLEON(c, m) || c->isfloating || c->isfullscreen)
|
|
||||||
continue;
|
|
||||||
if (i < m->nmaster) {
|
|
||||||
- resize(c, (struct wlr_box){.x = m->w.x, .y = m->w.y + my, .width = mw,
|
|
||||||
- .height = (m->w.height - my) / (MIN(n, m->nmaster) - i)}, 0);
|
|
||||||
- my += c->geom.height;
|
|
||||||
+ r = MIN(n, m->nmaster) - i;
|
|
||||||
+ h = (m->w.height - my - gappx*e - gappx*e * (r - 1)) / r;
|
|
||||||
+ resize(c, (struct wlr_box){.x = m->w.x + gappx*e, .y = m->w.y + my,
|
|
||||||
+ .width = mw - gappx*e, .height = h}, 0);
|
|
||||||
+ my += c->geom.height + gappx*e;
|
|
||||||
} else {
|
|
||||||
- resize(c, (struct wlr_box){.x = m->w.x + mw, .y = m->w.y + ty,
|
|
||||||
- .width = m->w.width - mw, .height = (m->w.height - ty) / (n - i)}, 0);
|
|
||||||
- ty += c->geom.height;
|
|
||||||
+ r = n - i;
|
|
||||||
+ h = (m->w.height - ty - gappx*e - gappx*e * (r - 1)) / r;
|
|
||||||
+ resize(c, (struct wlr_box){.x = m->w.x + mw + gappx*e, .y = m->w.y + ty,
|
|
||||||
+ .width = m->w.width - mw - 2*gappx*e, .height = h}, 0);
|
|
||||||
+ ty += c->geom.height + gappx*e;
|
|
||||||
}
|
|
||||||
i++;
|
|
||||||
}
|
|
||||||
@@ -2620,6 +2631,13 @@ togglefullscreen(const Arg *arg)
|
|
||||||
setfullscreen(sel, !sel->isfullscreen);
|
|
||||||
}
|
|
||||||
|
|
||||||
+void
|
|
||||||
+togglegaps(const Arg *arg)
|
|
||||||
+{
|
|
||||||
+ selmon->gaps = !selmon->gaps;
|
|
||||||
+ arrange(selmon);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
void
|
|
||||||
toggletag(const Arg *arg)
|
|
||||||
{
|
|
||||||
--
|
|
||||||
2.44.0
|
|
||||||
|
|
||||||
@@ -1,594 +0,0 @@
|
|||||||
From 5bbb9d70ab0a8322d1556ac0983eb3140b1c5dcd Mon Sep 17 00:00:00 2001
|
|
||||||
From: choc <notchoc@proton.me>
|
|
||||||
Date: Mon, 23 Oct 2023 10:35:17 +0800
|
|
||||||
Subject: [PATCH] implement dwl-ipc-unstable-v2
|
|
||||||
https://codeberg.org/dwl/dwl-patches/wiki/ipc
|
|
||||||
|
|
||||||
---
|
|
||||||
Makefile | 13 +-
|
|
||||||
config.def.h | 1 +
|
|
||||||
dwl.c | 257 ++++++++++++++++++++++++++----
|
|
||||||
protocols/dwl-ipc-unstable-v2.xml | 181 +++++++++++++++++++++
|
|
||||||
4 files changed, 415 insertions(+), 37 deletions(-)
|
|
||||||
create mode 100644 protocols/dwl-ipc-unstable-v2.xml
|
|
||||||
|
|
||||||
diff --git a/Makefile b/Makefile
|
|
||||||
index a67fdd3..2b45b2c 100644
|
|
||||||
--- a/Makefile
|
|
||||||
+++ b/Makefile
|
|
||||||
@@ -14,10 +14,11 @@ DWLCFLAGS = `$(PKG_CONFIG) --cflags $(PKGS)` $(DWLCPPFLAGS) $(DWLDEVCFLAGS) $(CF
|
|
||||||
LDLIBS = `$(PKG_CONFIG) --libs $(PKGS)` $(LIBS)
|
|
||||||
|
|
||||||
all: dwl
|
|
||||||
-dwl: dwl.o util.o
|
|
||||||
- $(CC) dwl.o util.o $(LDLIBS) $(LDFLAGS) $(DWLCFLAGS) -o $@
|
|
||||||
-dwl.o: dwl.c config.mk config.h client.h cursor-shape-v1-protocol.h pointer-constraints-unstable-v1-protocol.h wlr-layer-shell-unstable-v1-protocol.h xdg-shell-protocol.h
|
|
||||||
+dwl: dwl.o util.o dwl-ipc-unstable-v2-protocol.o
|
|
||||||
+ $(CC) dwl.o util.o dwl-ipc-unstable-v2-protocol.o $(LDLIBS) $(LDFLAGS) $(DWLCFLAGS) -o $@
|
|
||||||
+dwl.o: dwl.c config.mk config.h client.h cursor-shape-v1-protocol.h pointer-constraints-unstable-v1-protocol.h wlr-layer-shell-unstable-v1-protocol.h xdg-shell-protocol.h dwl-ipc-unstable-v2-protocol.h
|
|
||||||
util.o: util.c util.h
|
|
||||||
+dwl-ipc-unstable-v2-protocol.o: dwl-ipc-unstable-v2-protocol.c dwl-ipc-unstable-v2-protocol.h
|
|
||||||
|
|
||||||
# wayland-scanner is a tool which generates C headers and rigging for Wayland
|
|
||||||
# protocols, which are specified in XML. wlroots requires you to rig these up
|
|
||||||
@@ -37,6 +38,12 @@ wlr-layer-shell-unstable-v1-protocol.h:
|
|
||||||
xdg-shell-protocol.h:
|
|
||||||
$(WAYLAND_SCANNER) server-header \
|
|
||||||
$(WAYLAND_PROTOCOLS)/stable/xdg-shell/xdg-shell.xml $@
|
|
||||||
+dwl-ipc-unstable-v2-protocol.h:
|
|
||||||
+ $(WAYLAND_SCANNER) server-header \
|
|
||||||
+ protocols/dwl-ipc-unstable-v2.xml $@
|
|
||||||
+dwl-ipc-unstable-v2-protocol.c:
|
|
||||||
+ $(WAYLAND_SCANNER) private-code \
|
|
||||||
+ protocols/dwl-ipc-unstable-v2.xml $@
|
|
||||||
|
|
||||||
config.h:
|
|
||||||
cp config.def.h $@
|
|
||||||
diff --git a/config.def.h b/config.def.h
|
|
||||||
index 9009517..3467fed 100644
|
|
||||||
--- a/config.def.h
|
|
||||||
+++ b/config.def.h
|
|
||||||
@@ -122,6 +122,7 @@ static const Key keys[] = {
|
|
||||||
/* modifier key function argument */
|
|
||||||
{ MODKEY, XKB_KEY_p, spawn, {.v = menucmd} },
|
|
||||||
{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_Return, spawn, {.v = termcmd} },
|
|
||||||
+ { MODKEY, XKB_KEY_b, togglebar, {0} },
|
|
||||||
{ MODKEY, XKB_KEY_j, focusstack, {.i = +1} },
|
|
||||||
{ MODKEY, XKB_KEY_k, focusstack, {.i = -1} },
|
|
||||||
{ MODKEY, XKB_KEY_i, incnmaster, {.i = +1} },
|
|
||||||
diff --git a/dwl.c b/dwl.c
|
|
||||||
index d508d79..5f8af37 100644
|
|
||||||
--- a/dwl.c
|
|
||||||
+++ b/dwl.c
|
|
||||||
@@ -64,6 +64,7 @@
|
|
||||||
#include <xcb/xcb_icccm.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
+#include "dwl-ipc-unstable-v2-protocol.h"
|
|
||||||
#include "util.h"
|
|
||||||
|
|
||||||
/* macros */
|
|
||||||
@@ -141,6 +142,12 @@ typedef struct {
|
|
||||||
uint32_t resize; /* configure serial of a pending resize */
|
|
||||||
} Client;
|
|
||||||
|
|
||||||
+typedef struct {
|
|
||||||
+ struct wl_list link;
|
|
||||||
+ struct wl_resource *resource;
|
|
||||||
+ Monitor *mon;
|
|
||||||
+} DwlIpcOutput;
|
|
||||||
+
|
|
||||||
typedef struct {
|
|
||||||
uint32_t mod;
|
|
||||||
xkb_keysym_t keysym;
|
|
||||||
@@ -186,6 +193,7 @@ typedef struct {
|
|
||||||
|
|
||||||
struct Monitor {
|
|
||||||
struct wl_list link;
|
|
||||||
+ struct wl_list dwl_ipc_outputs;
|
|
||||||
struct wlr_output *wlr_output;
|
|
||||||
struct wlr_scene_output *scene_output;
|
|
||||||
struct wlr_scene_rect *fullscreen_bg; /* See createmon() for info */
|
|
||||||
@@ -278,6 +286,17 @@ static void destroypointerconstraint(struct wl_listener *listener, void *data);
|
|
||||||
static void destroysessionlock(struct wl_listener *listener, void *data);
|
|
||||||
static void destroysessionmgr(struct wl_listener *listener, void *data);
|
|
||||||
static Monitor *dirtomon(enum wlr_direction dir);
|
|
||||||
+static void dwl_ipc_manager_bind(struct wl_client *client, void *data, uint32_t version, uint32_t id);
|
|
||||||
+static void dwl_ipc_manager_destroy(struct wl_resource *resource);
|
|
||||||
+static void dwl_ipc_manager_get_output(struct wl_client *client, struct wl_resource *resource, uint32_t id, struct wl_resource *output);
|
|
||||||
+static void dwl_ipc_manager_release(struct wl_client *client, struct wl_resource *resource);
|
|
||||||
+static void dwl_ipc_output_destroy(struct wl_resource *resource);
|
|
||||||
+static void dwl_ipc_output_printstatus(Monitor *monitor);
|
|
||||||
+static void dwl_ipc_output_printstatus_to(DwlIpcOutput *ipc_output);
|
|
||||||
+static void dwl_ipc_output_set_client_tags(struct wl_client *client, struct wl_resource *resource, uint32_t and_tags, uint32_t xor_tags);
|
|
||||||
+static void dwl_ipc_output_set_layout(struct wl_client *client, struct wl_resource *resource, uint32_t index);
|
|
||||||
+static void dwl_ipc_output_set_tags(struct wl_client *client, struct wl_resource *resource, uint32_t tagmask, uint32_t toggle_tagset);
|
|
||||||
+static void dwl_ipc_output_release(struct wl_client *client, struct wl_resource *resource);
|
|
||||||
static void focusclient(Client *c, int lift);
|
|
||||||
static void focusmon(const Arg *arg);
|
|
||||||
static void focusstack(const Arg *arg);
|
|
||||||
@@ -330,6 +349,7 @@ static void startdrag(struct wl_listener *listener, void *data);
|
|
||||||
static void tag(const Arg *arg);
|
|
||||||
static void tagmon(const Arg *arg);
|
|
||||||
static void tile(Monitor *m);
|
|
||||||
+static void togglebar(const Arg *arg);
|
|
||||||
static void togglefloating(const Arg *arg);
|
|
||||||
static void togglefullscreen(const Arg *arg);
|
|
||||||
static void toggletag(const Arg *arg);
|
|
||||||
@@ -405,6 +425,9 @@ static struct wlr_box sgeom;
|
|
||||||
static struct wl_list mons;
|
|
||||||
static Monitor *selmon;
|
|
||||||
|
|
||||||
+static struct zdwl_ipc_manager_v2_interface dwl_manager_implementation = {.release = dwl_ipc_manager_release, .get_output = dwl_ipc_manager_get_output};
|
|
||||||
+static struct zdwl_ipc_output_v2_interface dwl_output_implementation = {.release = dwl_ipc_output_release, .set_tags = dwl_ipc_output_set_tags, .set_layout = dwl_ipc_output_set_layout, .set_client_tags = dwl_ipc_output_set_client_tags};
|
|
||||||
+
|
|
||||||
#ifdef XWAYLAND
|
|
||||||
static void activatex11(struct wl_listener *listener, void *data);
|
|
||||||
static void associatex11(struct wl_listener *listener, void *data);
|
|
||||||
@@ -684,6 +707,10 @@ cleanupmon(struct wl_listener *listener, void *data)
|
|
||||||
LayerSurface *l, *tmp;
|
|
||||||
size_t i;
|
|
||||||
|
|
||||||
+ DwlIpcOutput *ipc_output, *ipc_output_tmp;
|
|
||||||
+ wl_list_for_each_safe(ipc_output, ipc_output_tmp, &m->dwl_ipc_outputs, link)
|
|
||||||
+ wl_resource_destroy(ipc_output->resource);
|
|
||||||
+
|
|
||||||
/* m->layers[i] are intentionally not unlinked */
|
|
||||||
for (i = 0; i < LENGTH(m->layers); i++) {
|
|
||||||
wl_list_for_each_safe(l, tmp, &m->layers[i], link)
|
|
||||||
@@ -876,6 +903,8 @@ createmon(struct wl_listener *listener, void *data)
|
|
||||||
m = wlr_output->data = ecalloc(1, sizeof(*m));
|
|
||||||
m->wlr_output = wlr_output;
|
|
||||||
|
|
||||||
+ wl_list_init(&m->dwl_ipc_outputs);
|
|
||||||
+
|
|
||||||
for (i = 0; i < LENGTH(m->layers); i++)
|
|
||||||
wl_list_init(&m->layers[i]);
|
|
||||||
|
|
||||||
@@ -1233,6 +1262,190 @@ dirtomon(enum wlr_direction dir)
|
|
||||||
return selmon;
|
|
||||||
}
|
|
||||||
|
|
||||||
+void
|
|
||||||
+dwl_ipc_manager_bind(struct wl_client *client, void *data, uint32_t version, uint32_t id)
|
|
||||||
+{
|
|
||||||
+ struct wl_resource *manager_resource = wl_resource_create(client, &zdwl_ipc_manager_v2_interface, version, id);
|
|
||||||
+ if (!manager_resource) {
|
|
||||||
+ wl_client_post_no_memory(client);
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ wl_resource_set_implementation(manager_resource, &dwl_manager_implementation, NULL, dwl_ipc_manager_destroy);
|
|
||||||
+
|
|
||||||
+ zdwl_ipc_manager_v2_send_tags(manager_resource, TAGCOUNT);
|
|
||||||
+
|
|
||||||
+ for (unsigned int i = 0; i < LENGTH(layouts); i++)
|
|
||||||
+ zdwl_ipc_manager_v2_send_layout(manager_resource, layouts[i].symbol);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_manager_destroy(struct wl_resource *resource)
|
|
||||||
+{
|
|
||||||
+ /* No state to destroy */
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_manager_get_output(struct wl_client *client, struct wl_resource *resource, uint32_t id, struct wl_resource *output)
|
|
||||||
+{
|
|
||||||
+ DwlIpcOutput *ipc_output;
|
|
||||||
+ Monitor *monitor = wlr_output_from_resource(output)->data;
|
|
||||||
+ struct wl_resource *output_resource = wl_resource_create(client, &zdwl_ipc_output_v2_interface, wl_resource_get_version(resource), id);
|
|
||||||
+ if (!output_resource)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ ipc_output = ecalloc(1, sizeof(*ipc_output));
|
|
||||||
+ ipc_output->resource = output_resource;
|
|
||||||
+ ipc_output->mon = monitor;
|
|
||||||
+ wl_resource_set_implementation(output_resource, &dwl_output_implementation, ipc_output, dwl_ipc_output_destroy);
|
|
||||||
+ wl_list_insert(&monitor->dwl_ipc_outputs, &ipc_output->link);
|
|
||||||
+ dwl_ipc_output_printstatus_to(ipc_output);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_manager_release(struct wl_client *client, struct wl_resource *resource)
|
|
||||||
+{
|
|
||||||
+ wl_resource_destroy(resource);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+static void
|
|
||||||
+dwl_ipc_output_destroy(struct wl_resource *resource)
|
|
||||||
+{
|
|
||||||
+ DwlIpcOutput *ipc_output = wl_resource_get_user_data(resource);
|
|
||||||
+ wl_list_remove(&ipc_output->link);
|
|
||||||
+ free(ipc_output);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_output_printstatus(Monitor *monitor)
|
|
||||||
+{
|
|
||||||
+ DwlIpcOutput *ipc_output;
|
|
||||||
+ wl_list_for_each(ipc_output, &monitor->dwl_ipc_outputs, link)
|
|
||||||
+ dwl_ipc_output_printstatus_to(ipc_output);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_output_printstatus_to(DwlIpcOutput *ipc_output)
|
|
||||||
+{
|
|
||||||
+ Monitor *monitor = ipc_output->mon;
|
|
||||||
+ Client *c, *focused;
|
|
||||||
+ int tagmask, state, numclients, focused_client, tag;
|
|
||||||
+ const char *title, *appid;
|
|
||||||
+ focused = focustop(monitor);
|
|
||||||
+ zdwl_ipc_output_v2_send_active(ipc_output->resource, monitor == selmon);
|
|
||||||
+
|
|
||||||
+ for (tag = 0 ; tag < TAGCOUNT; tag++) {
|
|
||||||
+ numclients = state = focused_client = 0;
|
|
||||||
+ tagmask = 1 << tag;
|
|
||||||
+ if ((tagmask & monitor->tagset[monitor->seltags]) != 0)
|
|
||||||
+ state |= ZDWL_IPC_OUTPUT_V2_TAG_STATE_ACTIVE;
|
|
||||||
+
|
|
||||||
+ wl_list_for_each(c, &clients, link) {
|
|
||||||
+ if (c->mon != monitor)
|
|
||||||
+ continue;
|
|
||||||
+ if (!(c->tags & tagmask))
|
|
||||||
+ continue;
|
|
||||||
+ if (c == focused)
|
|
||||||
+ focused_client = 1;
|
|
||||||
+ if (c->isurgent)
|
|
||||||
+ state |= ZDWL_IPC_OUTPUT_V2_TAG_STATE_URGENT;
|
|
||||||
+
|
|
||||||
+ numclients++;
|
|
||||||
+ }
|
|
||||||
+ zdwl_ipc_output_v2_send_tag(ipc_output->resource, tag, state, numclients, focused_client);
|
|
||||||
+ }
|
|
||||||
+ title = focused ? client_get_title(focused) : "";
|
|
||||||
+ appid = focused ? client_get_appid(focused) : "";
|
|
||||||
+
|
|
||||||
+ zdwl_ipc_output_v2_send_layout(ipc_output->resource, monitor->lt[monitor->sellt] - layouts);
|
|
||||||
+ zdwl_ipc_output_v2_send_title(ipc_output->resource, title ? title : broken);
|
|
||||||
+ zdwl_ipc_output_v2_send_appid(ipc_output->resource, appid ? appid : broken);
|
|
||||||
+ zdwl_ipc_output_v2_send_layout_symbol(ipc_output->resource, monitor->ltsymbol);
|
|
||||||
+ if (wl_resource_get_version(ipc_output->resource) >= ZDWL_IPC_OUTPUT_V2_FULLSCREEN_SINCE_VERSION) {
|
|
||||||
+ zdwl_ipc_output_v2_send_fullscreen(ipc_output->resource, focused ? focused->isfullscreen : 0);
|
|
||||||
+ }
|
|
||||||
+ if (wl_resource_get_version(ipc_output->resource) >= ZDWL_IPC_OUTPUT_V2_FLOATING_SINCE_VERSION) {
|
|
||||||
+ zdwl_ipc_output_v2_send_floating(ipc_output->resource, focused ? focused->isfloating : 0);
|
|
||||||
+ }
|
|
||||||
+ zdwl_ipc_output_v2_send_frame(ipc_output->resource);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_output_set_client_tags(struct wl_client *client, struct wl_resource *resource, uint32_t and_tags, uint32_t xor_tags)
|
|
||||||
+{
|
|
||||||
+ DwlIpcOutput *ipc_output;
|
|
||||||
+ Monitor *monitor;
|
|
||||||
+ Client *selected_client;
|
|
||||||
+ unsigned int newtags = 0;
|
|
||||||
+
|
|
||||||
+ ipc_output = wl_resource_get_user_data(resource);
|
|
||||||
+ if (!ipc_output)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ monitor = ipc_output->mon;
|
|
||||||
+ selected_client = focustop(monitor);
|
|
||||||
+ if (!selected_client)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ newtags = (selected_client->tags & and_tags) ^ xor_tags;
|
|
||||||
+ if (!newtags)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ selected_client->tags = newtags;
|
|
||||||
+ focusclient(focustop(selmon), 1);
|
|
||||||
+ arrange(selmon);
|
|
||||||
+ printstatus();
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_output_set_layout(struct wl_client *client, struct wl_resource *resource, uint32_t index)
|
|
||||||
+{
|
|
||||||
+ DwlIpcOutput *ipc_output;
|
|
||||||
+ Monitor *monitor;
|
|
||||||
+
|
|
||||||
+ ipc_output = wl_resource_get_user_data(resource);
|
|
||||||
+ if (!ipc_output)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ monitor = ipc_output->mon;
|
|
||||||
+ if (index >= LENGTH(layouts))
|
|
||||||
+ return;
|
|
||||||
+ if (index != monitor->lt[monitor->sellt] - layouts)
|
|
||||||
+ monitor->sellt ^= 1;
|
|
||||||
+
|
|
||||||
+ monitor->lt[monitor->sellt] = &layouts[index];
|
|
||||||
+ arrange(monitor);
|
|
||||||
+ printstatus();
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_output_set_tags(struct wl_client *client, struct wl_resource *resource, uint32_t tagmask, uint32_t toggle_tagset)
|
|
||||||
+{
|
|
||||||
+ DwlIpcOutput *ipc_output;
|
|
||||||
+ Monitor *monitor;
|
|
||||||
+ unsigned int newtags = tagmask & TAGMASK;
|
|
||||||
+
|
|
||||||
+ ipc_output = wl_resource_get_user_data(resource);
|
|
||||||
+ if (!ipc_output)
|
|
||||||
+ return;
|
|
||||||
+ monitor = ipc_output->mon;
|
|
||||||
+
|
|
||||||
+ if (!newtags || newtags == monitor->tagset[monitor->seltags])
|
|
||||||
+ return;
|
|
||||||
+ if (toggle_tagset)
|
|
||||||
+ monitor->seltags ^= 1;
|
|
||||||
+
|
|
||||||
+ monitor->tagset[monitor->seltags] = newtags;
|
|
||||||
+ focusclient(focustop(monitor), 1);
|
|
||||||
+ arrange(monitor);
|
|
||||||
+ printstatus();
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+void
|
|
||||||
+dwl_ipc_output_release(struct wl_client *client, struct wl_resource *resource)
|
|
||||||
+{
|
|
||||||
+ wl_resource_destroy(resource);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
void
|
|
||||||
focusclient(Client *c, int lift)
|
|
||||||
{
|
|
||||||
@@ -1905,41 +2118,9 @@ void
|
|
||||||
printstatus(void)
|
|
||||||
{
|
|
||||||
Monitor *m = NULL;
|
|
||||||
- Client *c;
|
|
||||||
- uint32_t occ, urg, sel;
|
|
||||||
- const char *appid, *title;
|
|
||||||
|
|
||||||
- wl_list_for_each(m, &mons, link) {
|
|
||||||
- occ = urg = 0;
|
|
||||||
- wl_list_for_each(c, &clients, link) {
|
|
||||||
- if (c->mon != m)
|
|
||||||
- continue;
|
|
||||||
- occ |= c->tags;
|
|
||||||
- if (c->isurgent)
|
|
||||||
- urg |= c->tags;
|
|
||||||
- }
|
|
||||||
- if ((c = focustop(m))) {
|
|
||||||
- title = client_get_title(c);
|
|
||||||
- appid = client_get_appid(c);
|
|
||||||
- printf("%s title %s\n", m->wlr_output->name, title ? title : broken);
|
|
||||||
- printf("%s appid %s\n", m->wlr_output->name, appid ? appid : broken);
|
|
||||||
- printf("%s fullscreen %d\n", m->wlr_output->name, c->isfullscreen);
|
|
||||||
- printf("%s floating %d\n", m->wlr_output->name, c->isfloating);
|
|
||||||
- sel = c->tags;
|
|
||||||
- } else {
|
|
||||||
- printf("%s title \n", m->wlr_output->name);
|
|
||||||
- printf("%s appid \n", m->wlr_output->name);
|
|
||||||
- printf("%s fullscreen \n", m->wlr_output->name);
|
|
||||||
- printf("%s floating \n", m->wlr_output->name);
|
|
||||||
- sel = 0;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- printf("%s selmon %u\n", m->wlr_output->name, m == selmon);
|
|
||||||
- printf("%s tags %"PRIu32" %"PRIu32" %"PRIu32" %"PRIu32"\n",
|
|
||||||
- m->wlr_output->name, occ, m->tagset[m->seltags], sel, urg);
|
|
||||||
- printf("%s layout %s\n", m->wlr_output->name, m->ltsymbol);
|
|
||||||
- }
|
|
||||||
- fflush(stdout);
|
|
||||||
+ wl_list_for_each(m, &mons, link)
|
|
||||||
+ dwl_ipc_output_printstatus(m);
|
|
||||||
}
|
|
||||||
|
|
||||||
void
|
|
||||||
@@ -2502,6 +2683,7 @@ setup(void)
|
|
||||||
LISTEN_STATIC(&output_mgr->events.test, outputmgrtest);
|
|
||||||
|
|
||||||
wlr_scene_set_presentation(scene, wlr_presentation_create(dpy, backend));
|
|
||||||
+ wl_global_create(dpy, &zdwl_ipc_manager_v2_interface, 2, NULL, dwl_ipc_manager_bind);
|
|
||||||
|
|
||||||
/* Make sure XWayland clients don't connect to the parent X server,
|
|
||||||
* e.g when running in the x11 backend or the wayland backend and the
|
|
||||||
@@ -2600,6 +2782,13 @@ tile(Monitor *m)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
+void
|
|
||||||
+togglebar(const Arg *arg) {
|
|
||||||
+ DwlIpcOutput *ipc_output;
|
|
||||||
+ wl_list_for_each(ipc_output, &selmon->dwl_ipc_outputs, link)
|
|
||||||
+ zdwl_ipc_output_v2_send_toggle_visibility(ipc_output->resource);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
void
|
|
||||||
togglefloating(const Arg *arg)
|
|
||||||
{
|
|
||||||
diff --git a/protocols/dwl-ipc-unstable-v2.xml b/protocols/dwl-ipc-unstable-v2.xml
|
|
||||||
new file mode 100644
|
|
||||||
index 0000000..0a6e7e5
|
|
||||||
--- /dev/null
|
|
||||||
+++ b/protocols/dwl-ipc-unstable-v2.xml
|
|
||||||
@@ -0,0 +1,181 @@
|
|
||||||
+<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
+<!--
|
|
||||||
+This is largely ripped from somebar's ipc patchset; just with some personal modifications.
|
|
||||||
+I would probably just submit raphi's patchset but I don't think that would be polite.
|
|
||||||
+-->
|
|
||||||
+<protocol name="dwl_ipc_unstable_v2">
|
|
||||||
+ <description summary="inter-proccess-communication about dwl's state">
|
|
||||||
+ This protocol allows clients to update and get updates from dwl.
|
|
||||||
+
|
|
||||||
+ Warning! The protocol described in this file is experimental and
|
|
||||||
+ backward incompatible changes may be made. Backward compatible
|
|
||||||
+ changes may be added together with the corresponding interface
|
|
||||||
+ version bump.
|
|
||||||
+ Backward incompatible changes are done by bumping the version
|
|
||||||
+ number in the protocol and interface names and resetting the
|
|
||||||
+ interface version. Once the protocol is to be declared stable,
|
|
||||||
+ the 'z' prefix and the version number in the protocol and
|
|
||||||
+ interface names are removed and the interface version number is
|
|
||||||
+ reset.
|
|
||||||
+ </description>
|
|
||||||
+
|
|
||||||
+ <interface name="zdwl_ipc_manager_v2" version="2">
|
|
||||||
+ <description summary="manage dwl state">
|
|
||||||
+ This interface is exposed as a global in wl_registry.
|
|
||||||
+
|
|
||||||
+ Clients can use this interface to get a dwl_ipc_output.
|
|
||||||
+ After binding the client will recieve the dwl_ipc_manager.tags and dwl_ipc_manager.layout events.
|
|
||||||
+ The dwl_ipc_manager.tags and dwl_ipc_manager.layout events expose tags and layouts to the client.
|
|
||||||
+ </description>
|
|
||||||
+
|
|
||||||
+ <request name="release" type="destructor">
|
|
||||||
+ <description summary="release dwl_ipc_manager">
|
|
||||||
+ Indicates that the client will not the dwl_ipc_manager object anymore.
|
|
||||||
+ Objects created through this instance are not affected.
|
|
||||||
+ </description>
|
|
||||||
+ </request>
|
|
||||||
+
|
|
||||||
+ <request name="get_output">
|
|
||||||
+ <description summary="get a dwl_ipc_outout for a wl_output">
|
|
||||||
+ Get a dwl_ipc_outout for the specified wl_output.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="id" type="new_id" interface="zdwl_ipc_output_v2"/>
|
|
||||||
+ <arg name="output" type="object" interface="wl_output"/>
|
|
||||||
+ </request>
|
|
||||||
+
|
|
||||||
+ <event name="tags">
|
|
||||||
+ <description summary="Announces tag amount">
|
|
||||||
+ This event is sent after binding.
|
|
||||||
+ A roundtrip after binding guarantees the client recieved all tags.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="amount" type="uint"/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="layout">
|
|
||||||
+ <description summary="Announces a layout">
|
|
||||||
+ This event is sent after binding.
|
|
||||||
+ A roundtrip after binding guarantees the client recieved all layouts.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="name" type="string"/>
|
|
||||||
+ </event>
|
|
||||||
+ </interface>
|
|
||||||
+
|
|
||||||
+ <interface name="zdwl_ipc_output_v2" version="2">
|
|
||||||
+ <description summary="control dwl output">
|
|
||||||
+ Observe and control a dwl output.
|
|
||||||
+
|
|
||||||
+ Events are double-buffered:
|
|
||||||
+ Clients should cache events and redraw when a dwl_ipc_output.frame event is sent.
|
|
||||||
+
|
|
||||||
+ Request are not double-buffered:
|
|
||||||
+ The compositor will update immediately upon request.
|
|
||||||
+ </description>
|
|
||||||
+
|
|
||||||
+ <enum name="tag_state">
|
|
||||||
+ <entry name="none" value="0" summary="no state"/>
|
|
||||||
+ <entry name="active" value="1" summary="tag is active"/>
|
|
||||||
+ <entry name="urgent" value="2" summary="tag has at least one urgent client"/>
|
|
||||||
+ </enum>
|
|
||||||
+
|
|
||||||
+ <request name="release" type="destructor">
|
|
||||||
+ <description summary="release dwl_ipc_outout">
|
|
||||||
+ Indicates to that the client no longer needs this dwl_ipc_output.
|
|
||||||
+ </description>
|
|
||||||
+ </request>
|
|
||||||
+
|
|
||||||
+ <event name="toggle_visibility">
|
|
||||||
+ <description summary="Toggle client visibilty">
|
|
||||||
+ Indicates the client should hide or show themselves.
|
|
||||||
+ If the client is visible then hide, if hidden then show.
|
|
||||||
+ </description>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="active">
|
|
||||||
+ <description summary="Update the selected output.">
|
|
||||||
+ Indicates if the output is active. Zero is invalid, nonzero is valid.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="active" type="uint"/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="tag">
|
|
||||||
+ <description summary="Update the state of a tag.">
|
|
||||||
+ Indicates that a tag has been updated.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="tag" type="uint" summary="Index of the tag"/>
|
|
||||||
+ <arg name="state" type="uint" enum="tag_state" summary="The state of the tag."/>
|
|
||||||
+ <arg name="clients" type="uint" summary="The number of clients in the tag."/>
|
|
||||||
+ <arg name="focused" type="uint" summary="If there is a focused client. Nonzero being valid, zero being invalid."/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="layout">
|
|
||||||
+ <description summary="Update the layout.">
|
|
||||||
+ Indicates a new layout is selected.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="layout" type="uint" summary="Index of the layout."/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="title">
|
|
||||||
+ <description summary="Update the title.">
|
|
||||||
+ Indicates the title has changed.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="title" type="string" summary="The new title name."/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="appid" since="1">
|
|
||||||
+ <description summary="Update the appid.">
|
|
||||||
+ Indicates the appid has changed.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="appid" type="string" summary="The new appid."/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="layout_symbol" since="1">
|
|
||||||
+ <description summary="Update the current layout symbol">
|
|
||||||
+ Indicates the layout has changed. Since layout symbols are dynamic.
|
|
||||||
+ As opposed to the zdwl_ipc_manager.layout event, this should take precendence when displaying.
|
|
||||||
+ You can ignore the zdwl_ipc_output.layout event.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="layout" type="string" summary="The new layout"/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="frame">
|
|
||||||
+ <description summary="The update sequence is done.">
|
|
||||||
+ Indicates that a sequence of status updates have finished and the client should redraw.
|
|
||||||
+ </description>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <request name="set_tags">
|
|
||||||
+ <description summary="Set the active tags of this output"/>
|
|
||||||
+ <arg name="tagmask" type="uint" summary="bitmask of the tags that should be set."/>
|
|
||||||
+ <arg name="toggle_tagset" type="uint" summary="toggle the selected tagset, zero for invalid, nonzero for valid."/>
|
|
||||||
+ </request>
|
|
||||||
+
|
|
||||||
+ <request name="set_client_tags">
|
|
||||||
+ <description summary="Set the tags of the focused client.">
|
|
||||||
+ The tags are updated as follows:
|
|
||||||
+ new_tags = (current_tags AND and_tags) XOR xor_tags
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="and_tags" type="uint"/>
|
|
||||||
+ <arg name="xor_tags" type="uint"/>
|
|
||||||
+ </request>
|
|
||||||
+
|
|
||||||
+ <request name="set_layout">
|
|
||||||
+ <description summary="Set the layout of this output"/>
|
|
||||||
+ <arg name="index" type="uint" summary="index of a layout recieved by dwl_ipc_manager.layout"/>
|
|
||||||
+ </request>
|
|
||||||
+
|
|
||||||
+ <!-- Version 2 -->
|
|
||||||
+ <event name="fullscreen" since="2">
|
|
||||||
+ <description summary="Update fullscreen status">
|
|
||||||
+ Indicates if the selected client on this output is fullscreen.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="is_fullscreen" type="uint" summary="If the selected client is fullscreen. Nonzero is valid, zero invalid"/>
|
|
||||||
+ </event>
|
|
||||||
+
|
|
||||||
+ <event name="floating" since="2">
|
|
||||||
+ <description summary="Update the floating status">
|
|
||||||
+ Indicates if the selected client on this output is floating.
|
|
||||||
+ </description>
|
|
||||||
+ <arg name="is_floating" type="uint" summary="If the selected client is floating. Nonzero is valid, zero invalid"/>
|
|
||||||
+ </event>
|
|
||||||
+ </interface>
|
|
||||||
+</protocol>
|
|
||||||
--
|
|
||||||
2.44.0
|
|
||||||
|
|
||||||
@@ -1,577 +0,0 @@
|
|||||||
/* Generated by wayland-scanner 1.22.0 */
|
|
||||||
|
|
||||||
#ifndef POINTER_CONSTRAINTS_UNSTABLE_V1_SERVER_PROTOCOL_H
|
|
||||||
#define POINTER_CONSTRAINTS_UNSTABLE_V1_SERVER_PROTOCOL_H
|
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stddef.h>
|
|
||||||
#include "wayland-server.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct wl_client;
|
|
||||||
struct wl_resource;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @page page_pointer_constraints_unstable_v1 The pointer_constraints_unstable_v1 protocol
|
|
||||||
* protocol for constraining pointer motions
|
|
||||||
*
|
|
||||||
* @section page_desc_pointer_constraints_unstable_v1 Description
|
|
||||||
*
|
|
||||||
* This protocol specifies a set of interfaces used for adding constraints to
|
|
||||||
* the motion of a pointer. Possible constraints include confining pointer
|
|
||||||
* motions to a given region, or locking it to its current position.
|
|
||||||
*
|
|
||||||
* In order to constrain the pointer, a client must first bind the global
|
|
||||||
* interface "wp_pointer_constraints" which, if a compositor supports pointer
|
|
||||||
* constraints, is exposed by the registry. Using the bound global object, the
|
|
||||||
* client uses the request that corresponds to the type of constraint it wants
|
|
||||||
* to make. See wp_pointer_constraints for more details.
|
|
||||||
*
|
|
||||||
* Warning! The protocol described in this file is experimental and backward
|
|
||||||
* incompatible changes may be made. Backward compatible changes may be added
|
|
||||||
* together with the corresponding interface version bump. Backward
|
|
||||||
* incompatible changes are done by bumping the version number in the protocol
|
|
||||||
* and interface names and resetting the interface version. Once the protocol
|
|
||||||
* is to be declared stable, the 'z' prefix and the version number in the
|
|
||||||
* protocol and interface names are removed and the interface version number is
|
|
||||||
* reset.
|
|
||||||
*
|
|
||||||
* @section page_ifaces_pointer_constraints_unstable_v1 Interfaces
|
|
||||||
* - @subpage page_iface_zwp_pointer_constraints_v1 - constrain the movement of a pointer
|
|
||||||
* - @subpage page_iface_zwp_locked_pointer_v1 - receive relative pointer motion events
|
|
||||||
* - @subpage page_iface_zwp_confined_pointer_v1 - confined pointer object
|
|
||||||
* @section page_copyright_pointer_constraints_unstable_v1 Copyright
|
|
||||||
* <pre>
|
|
||||||
*
|
|
||||||
* Copyright © 2014 Jonas Ådahl
|
|
||||||
* Copyright © 2015 Red Hat Inc.
|
|
||||||
*
|
|
||||||
* Permission is hereby granted, free of charge, to any person obtaining a
|
|
||||||
* copy of this software and associated documentation files (the "Software"),
|
|
||||||
* to deal in the Software without restriction, including without limitation
|
|
||||||
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
|
|
||||||
* and/or sell copies of the Software, and to permit persons to whom the
|
|
||||||
* Software is furnished to do so, subject to the following conditions:
|
|
||||||
*
|
|
||||||
* The above copyright notice and this permission notice (including the next
|
|
||||||
* paragraph) shall be included in all copies or substantial portions of the
|
|
||||||
* Software.
|
|
||||||
*
|
|
||||||
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
||||||
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
||||||
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
|
|
||||||
* THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
||||||
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
|
|
||||||
* FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
||||||
* DEALINGS IN THE SOFTWARE.
|
|
||||||
* </pre>
|
|
||||||
*/
|
|
||||||
struct wl_pointer;
|
|
||||||
struct wl_region;
|
|
||||||
struct wl_surface;
|
|
||||||
struct zwp_confined_pointer_v1;
|
|
||||||
struct zwp_locked_pointer_v1;
|
|
||||||
struct zwp_pointer_constraints_v1;
|
|
||||||
|
|
||||||
#ifndef ZWP_POINTER_CONSTRAINTS_V1_INTERFACE
|
|
||||||
#define ZWP_POINTER_CONSTRAINTS_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zwp_pointer_constraints_v1 zwp_pointer_constraints_v1
|
|
||||||
* @section page_iface_zwp_pointer_constraints_v1_desc Description
|
|
||||||
*
|
|
||||||
* The global interface exposing pointer constraining functionality. It
|
|
||||||
* exposes two requests: lock_pointer for locking the pointer to its
|
|
||||||
* position, and confine_pointer for locking the pointer to a region.
|
|
||||||
*
|
|
||||||
* The lock_pointer and confine_pointer requests create the objects
|
|
||||||
* wp_locked_pointer and wp_confined_pointer respectively, and the client can
|
|
||||||
* use these objects to interact with the lock.
|
|
||||||
*
|
|
||||||
* For any surface, only one lock or confinement may be active across all
|
|
||||||
* wl_pointer objects of the same seat. If a lock or confinement is requested
|
|
||||||
* when another lock or confinement is active or requested on the same surface
|
|
||||||
* and with any of the wl_pointer objects of the same seat, an
|
|
||||||
* 'already_constrained' error will be raised.
|
|
||||||
* @section page_iface_zwp_pointer_constraints_v1_api API
|
|
||||||
* See @ref iface_zwp_pointer_constraints_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zwp_pointer_constraints_v1 The zwp_pointer_constraints_v1 interface
|
|
||||||
*
|
|
||||||
* The global interface exposing pointer constraining functionality. It
|
|
||||||
* exposes two requests: lock_pointer for locking the pointer to its
|
|
||||||
* position, and confine_pointer for locking the pointer to a region.
|
|
||||||
*
|
|
||||||
* The lock_pointer and confine_pointer requests create the objects
|
|
||||||
* wp_locked_pointer and wp_confined_pointer respectively, and the client can
|
|
||||||
* use these objects to interact with the lock.
|
|
||||||
*
|
|
||||||
* For any surface, only one lock or confinement may be active across all
|
|
||||||
* wl_pointer objects of the same seat. If a lock or confinement is requested
|
|
||||||
* when another lock or confinement is active or requested on the same surface
|
|
||||||
* and with any of the wl_pointer objects of the same seat, an
|
|
||||||
* 'already_constrained' error will be raised.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zwp_pointer_constraints_v1_interface;
|
|
||||||
#endif
|
|
||||||
#ifndef ZWP_LOCKED_POINTER_V1_INTERFACE
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zwp_locked_pointer_v1 zwp_locked_pointer_v1
|
|
||||||
* @section page_iface_zwp_locked_pointer_v1_desc Description
|
|
||||||
*
|
|
||||||
* The wp_locked_pointer interface represents a locked pointer state.
|
|
||||||
*
|
|
||||||
* While the lock of this object is active, the wl_pointer objects of the
|
|
||||||
* associated seat will not emit any wl_pointer.motion events.
|
|
||||||
*
|
|
||||||
* This object will send the event 'locked' when the lock is activated.
|
|
||||||
* Whenever the lock is activated, it is guaranteed that the locked surface
|
|
||||||
* will already have received pointer focus and that the pointer will be
|
|
||||||
* within the region passed to the request creating this object.
|
|
||||||
*
|
|
||||||
* To unlock the pointer, send the destroy request. This will also destroy
|
|
||||||
* the wp_locked_pointer object.
|
|
||||||
*
|
|
||||||
* If the compositor decides to unlock the pointer the unlocked event is
|
|
||||||
* sent. See wp_locked_pointer.unlock for details.
|
|
||||||
*
|
|
||||||
* When unlocking, the compositor may warp the cursor position to the set
|
|
||||||
* cursor position hint. If it does, it will not result in any relative
|
|
||||||
* motion events emitted via wp_relative_pointer.
|
|
||||||
*
|
|
||||||
* If the surface the lock was requested on is destroyed and the lock is not
|
|
||||||
* yet activated, the wp_locked_pointer object is now defunct and must be
|
|
||||||
* destroyed.
|
|
||||||
* @section page_iface_zwp_locked_pointer_v1_api API
|
|
||||||
* See @ref iface_zwp_locked_pointer_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zwp_locked_pointer_v1 The zwp_locked_pointer_v1 interface
|
|
||||||
*
|
|
||||||
* The wp_locked_pointer interface represents a locked pointer state.
|
|
||||||
*
|
|
||||||
* While the lock of this object is active, the wl_pointer objects of the
|
|
||||||
* associated seat will not emit any wl_pointer.motion events.
|
|
||||||
*
|
|
||||||
* This object will send the event 'locked' when the lock is activated.
|
|
||||||
* Whenever the lock is activated, it is guaranteed that the locked surface
|
|
||||||
* will already have received pointer focus and that the pointer will be
|
|
||||||
* within the region passed to the request creating this object.
|
|
||||||
*
|
|
||||||
* To unlock the pointer, send the destroy request. This will also destroy
|
|
||||||
* the wp_locked_pointer object.
|
|
||||||
*
|
|
||||||
* If the compositor decides to unlock the pointer the unlocked event is
|
|
||||||
* sent. See wp_locked_pointer.unlock for details.
|
|
||||||
*
|
|
||||||
* When unlocking, the compositor may warp the cursor position to the set
|
|
||||||
* cursor position hint. If it does, it will not result in any relative
|
|
||||||
* motion events emitted via wp_relative_pointer.
|
|
||||||
*
|
|
||||||
* If the surface the lock was requested on is destroyed and the lock is not
|
|
||||||
* yet activated, the wp_locked_pointer object is now defunct and must be
|
|
||||||
* destroyed.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zwp_locked_pointer_v1_interface;
|
|
||||||
#endif
|
|
||||||
#ifndef ZWP_CONFINED_POINTER_V1_INTERFACE
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zwp_confined_pointer_v1 zwp_confined_pointer_v1
|
|
||||||
* @section page_iface_zwp_confined_pointer_v1_desc Description
|
|
||||||
*
|
|
||||||
* The wp_confined_pointer interface represents a confined pointer state.
|
|
||||||
*
|
|
||||||
* This object will send the event 'confined' when the confinement is
|
|
||||||
* activated. Whenever the confinement is activated, it is guaranteed that
|
|
||||||
* the surface the pointer is confined to will already have received pointer
|
|
||||||
* focus and that the pointer will be within the region passed to the request
|
|
||||||
* creating this object. It is up to the compositor to decide whether this
|
|
||||||
* requires some user interaction and if the pointer will warp to within the
|
|
||||||
* passed region if outside.
|
|
||||||
*
|
|
||||||
* To unconfine the pointer, send the destroy request. This will also destroy
|
|
||||||
* the wp_confined_pointer object.
|
|
||||||
*
|
|
||||||
* If the compositor decides to unconfine the pointer the unconfined event is
|
|
||||||
* sent. The wp_confined_pointer object is at this point defunct and should
|
|
||||||
* be destroyed.
|
|
||||||
* @section page_iface_zwp_confined_pointer_v1_api API
|
|
||||||
* See @ref iface_zwp_confined_pointer_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zwp_confined_pointer_v1 The zwp_confined_pointer_v1 interface
|
|
||||||
*
|
|
||||||
* The wp_confined_pointer interface represents a confined pointer state.
|
|
||||||
*
|
|
||||||
* This object will send the event 'confined' when the confinement is
|
|
||||||
* activated. Whenever the confinement is activated, it is guaranteed that
|
|
||||||
* the surface the pointer is confined to will already have received pointer
|
|
||||||
* focus and that the pointer will be within the region passed to the request
|
|
||||||
* creating this object. It is up to the compositor to decide whether this
|
|
||||||
* requires some user interaction and if the pointer will warp to within the
|
|
||||||
* passed region if outside.
|
|
||||||
*
|
|
||||||
* To unconfine the pointer, send the destroy request. This will also destroy
|
|
||||||
* the wp_confined_pointer object.
|
|
||||||
*
|
|
||||||
* If the compositor decides to unconfine the pointer the unconfined event is
|
|
||||||
* sent. The wp_confined_pointer object is at this point defunct and should
|
|
||||||
* be destroyed.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zwp_confined_pointer_v1_interface;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef ZWP_POINTER_CONSTRAINTS_V1_ERROR_ENUM
|
|
||||||
#define ZWP_POINTER_CONSTRAINTS_V1_ERROR_ENUM
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_pointer_constraints_v1
|
|
||||||
* wp_pointer_constraints error values
|
|
||||||
*
|
|
||||||
* These errors can be emitted in response to wp_pointer_constraints
|
|
||||||
* requests.
|
|
||||||
*/
|
|
||||||
enum zwp_pointer_constraints_v1_error {
|
|
||||||
/**
|
|
||||||
* pointer constraint already requested on that surface
|
|
||||||
*/
|
|
||||||
ZWP_POINTER_CONSTRAINTS_V1_ERROR_ALREADY_CONSTRAINED = 1,
|
|
||||||
};
|
|
||||||
#endif /* ZWP_POINTER_CONSTRAINTS_V1_ERROR_ENUM */
|
|
||||||
|
|
||||||
#ifndef ZWP_POINTER_CONSTRAINTS_V1_LIFETIME_ENUM
|
|
||||||
#define ZWP_POINTER_CONSTRAINTS_V1_LIFETIME_ENUM
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_pointer_constraints_v1
|
|
||||||
* constraint lifetime
|
|
||||||
*
|
|
||||||
* These values represent different lifetime semantics. They are passed
|
|
||||||
* as arguments to the factory requests to specify how the constraint
|
|
||||||
* lifetimes should be managed.
|
|
||||||
*/
|
|
||||||
enum zwp_pointer_constraints_v1_lifetime {
|
|
||||||
/**
|
|
||||||
* the pointer constraint is defunct once deactivated
|
|
||||||
*
|
|
||||||
* A oneshot pointer constraint will never reactivate once it has
|
|
||||||
* been deactivated. See the corresponding deactivation event
|
|
||||||
* (wp_locked_pointer.unlocked and wp_confined_pointer.unconfined)
|
|
||||||
* for details.
|
|
||||||
*/
|
|
||||||
ZWP_POINTER_CONSTRAINTS_V1_LIFETIME_ONESHOT = 1,
|
|
||||||
/**
|
|
||||||
* the pointer constraint may reactivate
|
|
||||||
*
|
|
||||||
* A persistent pointer constraint may again reactivate once it
|
|
||||||
* has been deactivated. See the corresponding deactivation event
|
|
||||||
* (wp_locked_pointer.unlocked and wp_confined_pointer.unconfined)
|
|
||||||
* for details.
|
|
||||||
*/
|
|
||||||
ZWP_POINTER_CONSTRAINTS_V1_LIFETIME_PERSISTENT = 2,
|
|
||||||
};
|
|
||||||
#endif /* ZWP_POINTER_CONSTRAINTS_V1_LIFETIME_ENUM */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_pointer_constraints_v1
|
|
||||||
* @struct zwp_pointer_constraints_v1_interface
|
|
||||||
*/
|
|
||||||
struct zwp_pointer_constraints_v1_interface {
|
|
||||||
/**
|
|
||||||
* destroy the pointer constraints manager object
|
|
||||||
*
|
|
||||||
* Used by the client to notify the server that it will no longer
|
|
||||||
* use this pointer constraints object.
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* lock pointer to a position
|
|
||||||
*
|
|
||||||
* The lock_pointer request lets the client request to disable
|
|
||||||
* movements of the virtual pointer (i.e. the cursor), effectively
|
|
||||||
* locking the pointer to a position. This request may not take
|
|
||||||
* effect immediately; in the future, when the compositor deems
|
|
||||||
* implementation-specific constraints are satisfied, the pointer
|
|
||||||
* lock will be activated and the compositor sends a locked event.
|
|
||||||
*
|
|
||||||
* The protocol provides no guarantee that the constraints are ever
|
|
||||||
* satisfied, and does not require the compositor to send an error
|
|
||||||
* if the constraints cannot ever be satisfied. It is thus possible
|
|
||||||
* to request a lock that will never activate.
|
|
||||||
*
|
|
||||||
* There may not be another pointer constraint of any kind
|
|
||||||
* requested or active on the surface for any of the wl_pointer
|
|
||||||
* objects of the seat of the passed pointer when requesting a
|
|
||||||
* lock. If there is, an error will be raised. See general pointer
|
|
||||||
* lock documentation for more details.
|
|
||||||
*
|
|
||||||
* The intersection of the region passed with this request and the
|
|
||||||
* input region of the surface is used to determine where the
|
|
||||||
* pointer must be in order for the lock to activate. It is up to
|
|
||||||
* the compositor whether to warp the pointer or require some kind
|
|
||||||
* of user interaction for the lock to activate. If the region is
|
|
||||||
* null the surface input region is used.
|
|
||||||
*
|
|
||||||
* A surface may receive pointer focus without the lock being
|
|
||||||
* activated.
|
|
||||||
*
|
|
||||||
* The request creates a new object wp_locked_pointer which is used
|
|
||||||
* to interact with the lock as well as receive updates about its
|
|
||||||
* state. See the the description of wp_locked_pointer for further
|
|
||||||
* information.
|
|
||||||
*
|
|
||||||
* Note that while a pointer is locked, the wl_pointer objects of
|
|
||||||
* the corresponding seat will not emit any wl_pointer.motion
|
|
||||||
* events, but relative motion events will still be emitted via
|
|
||||||
* wp_relative_pointer objects of the same seat. wl_pointer.axis
|
|
||||||
* and wl_pointer.button events are unaffected.
|
|
||||||
* @param surface surface to lock pointer to
|
|
||||||
* @param pointer the pointer that should be locked
|
|
||||||
* @param region region of surface
|
|
||||||
* @param lifetime lock lifetime
|
|
||||||
*/
|
|
||||||
void (*lock_pointer)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t id,
|
|
||||||
struct wl_resource *surface,
|
|
||||||
struct wl_resource *pointer,
|
|
||||||
struct wl_resource *region,
|
|
||||||
uint32_t lifetime);
|
|
||||||
/**
|
|
||||||
* confine pointer to a region
|
|
||||||
*
|
|
||||||
* The confine_pointer request lets the client request to confine
|
|
||||||
* the pointer cursor to a given region. This request may not take
|
|
||||||
* effect immediately; in the future, when the compositor deems
|
|
||||||
* implementation- specific constraints are satisfied, the pointer
|
|
||||||
* confinement will be activated and the compositor sends a
|
|
||||||
* confined event.
|
|
||||||
*
|
|
||||||
* The intersection of the region passed with this request and the
|
|
||||||
* input region of the surface is used to determine where the
|
|
||||||
* pointer must be in order for the confinement to activate. It is
|
|
||||||
* up to the compositor whether to warp the pointer or require some
|
|
||||||
* kind of user interaction for the confinement to activate. If the
|
|
||||||
* region is null the surface input region is used.
|
|
||||||
*
|
|
||||||
* The request will create a new object wp_confined_pointer which
|
|
||||||
* is used to interact with the confinement as well as receive
|
|
||||||
* updates about its state. See the the description of
|
|
||||||
* wp_confined_pointer for further information.
|
|
||||||
* @param surface surface to lock pointer to
|
|
||||||
* @param pointer the pointer that should be confined
|
|
||||||
* @param region region of surface
|
|
||||||
* @param lifetime confinement lifetime
|
|
||||||
*/
|
|
||||||
void (*confine_pointer)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t id,
|
|
||||||
struct wl_resource *surface,
|
|
||||||
struct wl_resource *pointer,
|
|
||||||
struct wl_resource *region,
|
|
||||||
uint32_t lifetime);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_pointer_constraints_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_POINTER_CONSTRAINTS_V1_DESTROY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_pointer_constraints_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_POINTER_CONSTRAINTS_V1_LOCK_POINTER_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_pointer_constraints_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_POINTER_CONSTRAINTS_V1_CONFINE_POINTER_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
* @struct zwp_locked_pointer_v1_interface
|
|
||||||
*/
|
|
||||||
struct zwp_locked_pointer_v1_interface {
|
|
||||||
/**
|
|
||||||
* destroy the locked pointer object
|
|
||||||
*
|
|
||||||
* Destroy the locked pointer object. If applicable, the
|
|
||||||
* compositor will unlock the pointer.
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* set the pointer cursor position hint
|
|
||||||
*
|
|
||||||
* Set the cursor position hint relative to the top left corner
|
|
||||||
* of the surface.
|
|
||||||
*
|
|
||||||
* If the client is drawing its own cursor, it should update the
|
|
||||||
* position hint to the position of its own cursor. A compositor
|
|
||||||
* may use this information to warp the pointer upon unlock in
|
|
||||||
* order to avoid pointer jumps.
|
|
||||||
*
|
|
||||||
* The cursor position hint is double buffered. The new hint will
|
|
||||||
* only take effect when the associated surface gets it pending
|
|
||||||
* state applied. See wl_surface.commit for details.
|
|
||||||
* @param surface_x surface-local x coordinate
|
|
||||||
* @param surface_y surface-local y coordinate
|
|
||||||
*/
|
|
||||||
void (*set_cursor_position_hint)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
wl_fixed_t surface_x,
|
|
||||||
wl_fixed_t surface_y);
|
|
||||||
/**
|
|
||||||
* set a new lock region
|
|
||||||
*
|
|
||||||
* Set a new region used to lock the pointer.
|
|
||||||
*
|
|
||||||
* The new lock region is double-buffered. The new lock region will
|
|
||||||
* only take effect when the associated surface gets its pending
|
|
||||||
* state applied. See wl_surface.commit for details.
|
|
||||||
*
|
|
||||||
* For details about the lock region, see wp_locked_pointer.
|
|
||||||
* @param region region of surface
|
|
||||||
*/
|
|
||||||
void (*set_region)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
struct wl_resource *region);
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_LOCKED 0
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_UNLOCKED 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_LOCKED_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_UNLOCKED_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_DESTROY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_SET_CURSOR_POSITION_HINT_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_LOCKED_POINTER_V1_SET_REGION_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
* Sends an locked event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zwp_locked_pointer_v1_send_locked(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZWP_LOCKED_POINTER_V1_LOCKED);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_locked_pointer_v1
|
|
||||||
* Sends an unlocked event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zwp_locked_pointer_v1_send_unlocked(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZWP_LOCKED_POINTER_V1_UNLOCKED);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
* @struct zwp_confined_pointer_v1_interface
|
|
||||||
*/
|
|
||||||
struct zwp_confined_pointer_v1_interface {
|
|
||||||
/**
|
|
||||||
* destroy the confined pointer object
|
|
||||||
*
|
|
||||||
* Destroy the confined pointer object. If applicable, the
|
|
||||||
* compositor will unconfine the pointer.
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* set a new confine region
|
|
||||||
*
|
|
||||||
* Set a new region used to confine the pointer.
|
|
||||||
*
|
|
||||||
* The new confine region is double-buffered. The new confine
|
|
||||||
* region will only take effect when the associated surface gets
|
|
||||||
* its pending state applied. See wl_surface.commit for details.
|
|
||||||
*
|
|
||||||
* If the confinement is active when the new confinement region is
|
|
||||||
* applied and the pointer ends up outside of newly applied region,
|
|
||||||
* the pointer may warped to a position within the new confinement
|
|
||||||
* region. If warped, a wl_pointer.motion event will be emitted,
|
|
||||||
* but no wp_relative_pointer.relative_motion event.
|
|
||||||
*
|
|
||||||
* The compositor may also, instead of using the new region,
|
|
||||||
* unconfine the pointer.
|
|
||||||
*
|
|
||||||
* For details about the confine region, see wp_confined_pointer.
|
|
||||||
* @param region region of surface
|
|
||||||
*/
|
|
||||||
void (*set_region)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
struct wl_resource *region);
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_CONFINED 0
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_UNCONFINED 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_CONFINED_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_UNCONFINED_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_DESTROY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
*/
|
|
||||||
#define ZWP_CONFINED_POINTER_V1_SET_REGION_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
* Sends an confined event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zwp_confined_pointer_v1_send_confined(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZWP_CONFINED_POINTER_V1_CONFINED);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwp_confined_pointer_v1
|
|
||||||
* Sends an unconfined event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zwp_confined_pointer_v1_send_unconfined(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZWP_CONFINED_POINTER_V1_UNCONFINED);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
@@ -1,181 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
This is largely ripped from somebar's ipc patchset; just with some personal modifications.
|
|
||||||
I would probably just submit raphi's patchset but I don't think that would be polite.
|
|
||||||
-->
|
|
||||||
<protocol name="dwl_ipc_unstable_v2">
|
|
||||||
<description summary="inter-proccess-communication about dwl's state">
|
|
||||||
This protocol allows clients to update and get updates from dwl.
|
|
||||||
|
|
||||||
Warning! The protocol described in this file is experimental and
|
|
||||||
backward incompatible changes may be made. Backward compatible
|
|
||||||
changes may be added together with the corresponding interface
|
|
||||||
version bump.
|
|
||||||
Backward incompatible changes are done by bumping the version
|
|
||||||
number in the protocol and interface names and resetting the
|
|
||||||
interface version. Once the protocol is to be declared stable,
|
|
||||||
the 'z' prefix and the version number in the protocol and
|
|
||||||
interface names are removed and the interface version number is
|
|
||||||
reset.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<interface name="zdwl_ipc_manager_v2" version="2">
|
|
||||||
<description summary="manage dwl state">
|
|
||||||
This interface is exposed as a global in wl_registry.
|
|
||||||
|
|
||||||
Clients can use this interface to get a dwl_ipc_output.
|
|
||||||
After binding the client will recieve the dwl_ipc_manager.tags and dwl_ipc_manager.layout events.
|
|
||||||
The dwl_ipc_manager.tags and dwl_ipc_manager.layout events expose tags and layouts to the client.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<request name="release" type="destructor">
|
|
||||||
<description summary="release dwl_ipc_manager">
|
|
||||||
Indicates that the client will not the dwl_ipc_manager object anymore.
|
|
||||||
Objects created through this instance are not affected.
|
|
||||||
</description>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="get_output">
|
|
||||||
<description summary="get a dwl_ipc_outout for a wl_output">
|
|
||||||
Get a dwl_ipc_outout for the specified wl_output.
|
|
||||||
</description>
|
|
||||||
<arg name="id" type="new_id" interface="zdwl_ipc_output_v2"/>
|
|
||||||
<arg name="output" type="object" interface="wl_output"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<event name="tags">
|
|
||||||
<description summary="Announces tag amount">
|
|
||||||
This event is sent after binding.
|
|
||||||
A roundtrip after binding guarantees the client recieved all tags.
|
|
||||||
</description>
|
|
||||||
<arg name="amount" type="uint"/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="layout">
|
|
||||||
<description summary="Announces a layout">
|
|
||||||
This event is sent after binding.
|
|
||||||
A roundtrip after binding guarantees the client recieved all layouts.
|
|
||||||
</description>
|
|
||||||
<arg name="name" type="string"/>
|
|
||||||
</event>
|
|
||||||
</interface>
|
|
||||||
|
|
||||||
<interface name="zdwl_ipc_output_v2" version="2">
|
|
||||||
<description summary="control dwl output">
|
|
||||||
Observe and control a dwl output.
|
|
||||||
|
|
||||||
Events are double-buffered:
|
|
||||||
Clients should cache events and redraw when a dwl_ipc_output.frame event is sent.
|
|
||||||
|
|
||||||
Request are not double-buffered:
|
|
||||||
The compositor will update immediately upon request.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<enum name="tag_state">
|
|
||||||
<entry name="none" value="0" summary="no state"/>
|
|
||||||
<entry name="active" value="1" summary="tag is active"/>
|
|
||||||
<entry name="urgent" value="2" summary="tag has at least one urgent client"/>
|
|
||||||
</enum>
|
|
||||||
|
|
||||||
<request name="release" type="destructor">
|
|
||||||
<description summary="release dwl_ipc_outout">
|
|
||||||
Indicates to that the client no longer needs this dwl_ipc_output.
|
|
||||||
</description>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<event name="toggle_visibility">
|
|
||||||
<description summary="Toggle client visibilty">
|
|
||||||
Indicates the client should hide or show themselves.
|
|
||||||
If the client is visible then hide, if hidden then show.
|
|
||||||
</description>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="active">
|
|
||||||
<description summary="Update the selected output.">
|
|
||||||
Indicates if the output is active. Zero is invalid, nonzero is valid.
|
|
||||||
</description>
|
|
||||||
<arg name="active" type="uint"/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="tag">
|
|
||||||
<description summary="Update the state of a tag.">
|
|
||||||
Indicates that a tag has been updated.
|
|
||||||
</description>
|
|
||||||
<arg name="tag" type="uint" summary="Index of the tag"/>
|
|
||||||
<arg name="state" type="uint" enum="tag_state" summary="The state of the tag."/>
|
|
||||||
<arg name="clients" type="uint" summary="The number of clients in the tag."/>
|
|
||||||
<arg name="focused" type="uint" summary="If there is a focused client. Nonzero being valid, zero being invalid."/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="layout">
|
|
||||||
<description summary="Update the layout.">
|
|
||||||
Indicates a new layout is selected.
|
|
||||||
</description>
|
|
||||||
<arg name="layout" type="uint" summary="Index of the layout."/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="title">
|
|
||||||
<description summary="Update the title.">
|
|
||||||
Indicates the title has changed.
|
|
||||||
</description>
|
|
||||||
<arg name="title" type="string" summary="The new title name."/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="appid" since="1">
|
|
||||||
<description summary="Update the appid.">
|
|
||||||
Indicates the appid has changed.
|
|
||||||
</description>
|
|
||||||
<arg name="appid" type="string" summary="The new appid."/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="layout_symbol" since="1">
|
|
||||||
<description summary="Update the current layout symbol">
|
|
||||||
Indicates the layout has changed. Since layout symbols are dynamic.
|
|
||||||
As opposed to the zdwl_ipc_manager.layout event, this should take precendence when displaying.
|
|
||||||
You can ignore the zdwl_ipc_output.layout event.
|
|
||||||
</description>
|
|
||||||
<arg name="layout" type="string" summary="The new layout"/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="frame">
|
|
||||||
<description summary="The update sequence is done.">
|
|
||||||
Indicates that a sequence of status updates have finished and the client should redraw.
|
|
||||||
</description>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<request name="set_tags">
|
|
||||||
<description summary="Set the active tags of this output"/>
|
|
||||||
<arg name="tagmask" type="uint" summary="bitmask of the tags that should be set."/>
|
|
||||||
<arg name="toggle_tagset" type="uint" summary="toggle the selected tagset, zero for invalid, nonzero for valid."/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="set_client_tags">
|
|
||||||
<description summary="Set the tags of the focused client.">
|
|
||||||
The tags are updated as follows:
|
|
||||||
new_tags = (current_tags AND and_tags) XOR xor_tags
|
|
||||||
</description>
|
|
||||||
<arg name="and_tags" type="uint"/>
|
|
||||||
<arg name="xor_tags" type="uint"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="set_layout">
|
|
||||||
<description summary="Set the layout of this output"/>
|
|
||||||
<arg name="index" type="uint" summary="index of a layout recieved by dwl_ipc_manager.layout"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<!-- Version 2 -->
|
|
||||||
<event name="fullscreen" since="2">
|
|
||||||
<description summary="Update fullscreen status">
|
|
||||||
Indicates if the selected client on this output is fullscreen.
|
|
||||||
</description>
|
|
||||||
<arg name="is_fullscreen" type="uint" summary="If the selected client is fullscreen. Nonzero is valid, zero invalid"/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="floating" since="2">
|
|
||||||
<description summary="Update the floating status">
|
|
||||||
Indicates if the selected client on this output is floating.
|
|
||||||
</description>
|
|
||||||
<arg name="is_floating" type="uint" summary="If the selected client is floating. Nonzero is valid, zero invalid"/>
|
|
||||||
</event>
|
|
||||||
</interface>
|
|
||||||
</protocol>
|
|
||||||
@@ -1,390 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<protocol name="wlr_layer_shell_unstable_v1">
|
|
||||||
<copyright>
|
|
||||||
Copyright © 2017 Drew DeVault
|
|
||||||
|
|
||||||
Permission to use, copy, modify, distribute, and sell this
|
|
||||||
software and its documentation for any purpose is hereby granted
|
|
||||||
without fee, provided that the above copyright notice appear in
|
|
||||||
all copies and that both that copyright notice and this permission
|
|
||||||
notice appear in supporting documentation, and that the name of
|
|
||||||
the copyright holders not be used in advertising or publicity
|
|
||||||
pertaining to distribution of the software without specific,
|
|
||||||
written prior permission. The copyright holders make no
|
|
||||||
representations about the suitability of this software for any
|
|
||||||
purpose. It is provided "as is" without express or implied
|
|
||||||
warranty.
|
|
||||||
|
|
||||||
THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
|
||||||
SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
||||||
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
|
|
||||||
AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
|
|
||||||
ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
|
||||||
THIS SOFTWARE.
|
|
||||||
</copyright>
|
|
||||||
|
|
||||||
<interface name="zwlr_layer_shell_v1" version="4">
|
|
||||||
<description summary="create surfaces that are layers of the desktop">
|
|
||||||
Clients can use this interface to assign the surface_layer role to
|
|
||||||
wl_surfaces. Such surfaces are assigned to a "layer" of the output and
|
|
||||||
rendered with a defined z-depth respective to each other. They may also be
|
|
||||||
anchored to the edges and corners of a screen and specify input handling
|
|
||||||
semantics. This interface should be suitable for the implementation of
|
|
||||||
many desktop shell components, and a broad number of other applications
|
|
||||||
that interact with the desktop.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<request name="get_layer_surface">
|
|
||||||
<description summary="create a layer_surface from a surface">
|
|
||||||
Create a layer surface for an existing surface. This assigns the role of
|
|
||||||
layer_surface, or raises a protocol error if another role is already
|
|
||||||
assigned.
|
|
||||||
|
|
||||||
Creating a layer surface from a wl_surface which has a buffer attached
|
|
||||||
or committed is a client error, and any attempts by a client to attach
|
|
||||||
or manipulate a buffer prior to the first layer_surface.configure call
|
|
||||||
must also be treated as errors.
|
|
||||||
|
|
||||||
After creating a layer_surface object and setting it up, the client
|
|
||||||
must perform an initial commit without any buffer attached.
|
|
||||||
The compositor will reply with a layer_surface.configure event.
|
|
||||||
The client must acknowledge it and is then allowed to attach a buffer
|
|
||||||
to map the surface.
|
|
||||||
|
|
||||||
You may pass NULL for output to allow the compositor to decide which
|
|
||||||
output to use. Generally this will be the one that the user most
|
|
||||||
recently interacted with.
|
|
||||||
|
|
||||||
Clients can specify a namespace that defines the purpose of the layer
|
|
||||||
surface.
|
|
||||||
</description>
|
|
||||||
<arg name="id" type="new_id" interface="zwlr_layer_surface_v1"/>
|
|
||||||
<arg name="surface" type="object" interface="wl_surface"/>
|
|
||||||
<arg name="output" type="object" interface="wl_output" allow-null="true"/>
|
|
||||||
<arg name="layer" type="uint" enum="layer" summary="layer to add this surface to"/>
|
|
||||||
<arg name="namespace" type="string" summary="namespace for the layer surface"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<enum name="error">
|
|
||||||
<entry name="role" value="0" summary="wl_surface has another role"/>
|
|
||||||
<entry name="invalid_layer" value="1" summary="layer value is invalid"/>
|
|
||||||
<entry name="already_constructed" value="2" summary="wl_surface has a buffer attached or committed"/>
|
|
||||||
</enum>
|
|
||||||
|
|
||||||
<enum name="layer">
|
|
||||||
<description summary="available layers for surfaces">
|
|
||||||
These values indicate which layers a surface can be rendered in. They
|
|
||||||
are ordered by z depth, bottom-most first. Traditional shell surfaces
|
|
||||||
will typically be rendered between the bottom and top layers.
|
|
||||||
Fullscreen shell surfaces are typically rendered at the top layer.
|
|
||||||
Multiple surfaces can share a single layer, and ordering within a
|
|
||||||
single layer is undefined.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<entry name="background" value="0"/>
|
|
||||||
<entry name="bottom" value="1"/>
|
|
||||||
<entry name="top" value="2"/>
|
|
||||||
<entry name="overlay" value="3"/>
|
|
||||||
</enum>
|
|
||||||
|
|
||||||
<!-- Version 3 additions -->
|
|
||||||
|
|
||||||
<request name="destroy" type="destructor" since="3">
|
|
||||||
<description summary="destroy the layer_shell object">
|
|
||||||
This request indicates that the client will not use the layer_shell
|
|
||||||
object any more. Objects that have been created through this instance
|
|
||||||
are not affected.
|
|
||||||
</description>
|
|
||||||
</request>
|
|
||||||
</interface>
|
|
||||||
|
|
||||||
<interface name="zwlr_layer_surface_v1" version="4">
|
|
||||||
<description summary="layer metadata interface">
|
|
||||||
An interface that may be implemented by a wl_surface, for surfaces that
|
|
||||||
are designed to be rendered as a layer of a stacked desktop-like
|
|
||||||
environment.
|
|
||||||
|
|
||||||
Layer surface state (layer, size, anchor, exclusive zone,
|
|
||||||
margin, interactivity) is double-buffered, and will be applied at the
|
|
||||||
time wl_surface.commit of the corresponding wl_surface is called.
|
|
||||||
|
|
||||||
Attaching a null buffer to a layer surface unmaps it.
|
|
||||||
|
|
||||||
Unmapping a layer_surface means that the surface cannot be shown by the
|
|
||||||
compositor until it is explicitly mapped again. The layer_surface
|
|
||||||
returns to the state it had right after layer_shell.get_layer_surface.
|
|
||||||
The client can re-map the surface by performing a commit without any
|
|
||||||
buffer attached, waiting for a configure event and handling it as usual.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<request name="set_size">
|
|
||||||
<description summary="sets the size of the surface">
|
|
||||||
Sets the size of the surface in surface-local coordinates. The
|
|
||||||
compositor will display the surface centered with respect to its
|
|
||||||
anchors.
|
|
||||||
|
|
||||||
If you pass 0 for either value, the compositor will assign it and
|
|
||||||
inform you of the assignment in the configure event. You must set your
|
|
||||||
anchor to opposite edges in the dimensions you omit; not doing so is a
|
|
||||||
protocol error. Both values are 0 by default.
|
|
||||||
|
|
||||||
Size is double-buffered, see wl_surface.commit.
|
|
||||||
</description>
|
|
||||||
<arg name="width" type="uint"/>
|
|
||||||
<arg name="height" type="uint"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="set_anchor">
|
|
||||||
<description summary="configures the anchor point of the surface">
|
|
||||||
Requests that the compositor anchor the surface to the specified edges
|
|
||||||
and corners. If two orthogonal edges are specified (e.g. 'top' and
|
|
||||||
'left'), then the anchor point will be the intersection of the edges
|
|
||||||
(e.g. the top left corner of the output); otherwise the anchor point
|
|
||||||
will be centered on that edge, or in the center if none is specified.
|
|
||||||
|
|
||||||
Anchor is double-buffered, see wl_surface.commit.
|
|
||||||
</description>
|
|
||||||
<arg name="anchor" type="uint" enum="anchor"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="set_exclusive_zone">
|
|
||||||
<description summary="configures the exclusive geometry of this surface">
|
|
||||||
Requests that the compositor avoids occluding an area with other
|
|
||||||
surfaces. The compositor's use of this information is
|
|
||||||
implementation-dependent - do not assume that this region will not
|
|
||||||
actually be occluded.
|
|
||||||
|
|
||||||
A positive value is only meaningful if the surface is anchored to one
|
|
||||||
edge or an edge and both perpendicular edges. If the surface is not
|
|
||||||
anchored, anchored to only two perpendicular edges (a corner), anchored
|
|
||||||
to only two parallel edges or anchored to all edges, a positive value
|
|
||||||
will be treated the same as zero.
|
|
||||||
|
|
||||||
A positive zone is the distance from the edge in surface-local
|
|
||||||
coordinates to consider exclusive.
|
|
||||||
|
|
||||||
Surfaces that do not wish to have an exclusive zone may instead specify
|
|
||||||
how they should interact with surfaces that do. If set to zero, the
|
|
||||||
surface indicates that it would like to be moved to avoid occluding
|
|
||||||
surfaces with a positive exclusive zone. If set to -1, the surface
|
|
||||||
indicates that it would not like to be moved to accommodate for other
|
|
||||||
surfaces, and the compositor should extend it all the way to the edges
|
|
||||||
it is anchored to.
|
|
||||||
|
|
||||||
For example, a panel might set its exclusive zone to 10, so that
|
|
||||||
maximized shell surfaces are not shown on top of it. A notification
|
|
||||||
might set its exclusive zone to 0, so that it is moved to avoid
|
|
||||||
occluding the panel, but shell surfaces are shown underneath it. A
|
|
||||||
wallpaper or lock screen might set their exclusive zone to -1, so that
|
|
||||||
they stretch below or over the panel.
|
|
||||||
|
|
||||||
The default value is 0.
|
|
||||||
|
|
||||||
Exclusive zone is double-buffered, see wl_surface.commit.
|
|
||||||
</description>
|
|
||||||
<arg name="zone" type="int"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="set_margin">
|
|
||||||
<description summary="sets a margin from the anchor point">
|
|
||||||
Requests that the surface be placed some distance away from the anchor
|
|
||||||
point on the output, in surface-local coordinates. Setting this value
|
|
||||||
for edges you are not anchored to has no effect.
|
|
||||||
|
|
||||||
The exclusive zone includes the margin.
|
|
||||||
|
|
||||||
Margin is double-buffered, see wl_surface.commit.
|
|
||||||
</description>
|
|
||||||
<arg name="top" type="int"/>
|
|
||||||
<arg name="right" type="int"/>
|
|
||||||
<arg name="bottom" type="int"/>
|
|
||||||
<arg name="left" type="int"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<enum name="keyboard_interactivity">
|
|
||||||
<description summary="types of keyboard interaction possible for a layer shell surface">
|
|
||||||
Types of keyboard interaction possible for layer shell surfaces. The
|
|
||||||
rationale for this is twofold: (1) some applications are not interested
|
|
||||||
in keyboard events and not allowing them to be focused can improve the
|
|
||||||
desktop experience; (2) some applications will want to take exclusive
|
|
||||||
keyboard focus.
|
|
||||||
</description>
|
|
||||||
|
|
||||||
<entry name="none" value="0">
|
|
||||||
<description summary="no keyboard focus is possible">
|
|
||||||
This value indicates that this surface is not interested in keyboard
|
|
||||||
events and the compositor should never assign it the keyboard focus.
|
|
||||||
|
|
||||||
This is the default value, set for newly created layer shell surfaces.
|
|
||||||
|
|
||||||
This is useful for e.g. desktop widgets that display information or
|
|
||||||
only have interaction with non-keyboard input devices.
|
|
||||||
</description>
|
|
||||||
</entry>
|
|
||||||
<entry name="exclusive" value="1">
|
|
||||||
<description summary="request exclusive keyboard focus">
|
|
||||||
Request exclusive keyboard focus if this surface is above the shell surface layer.
|
|
||||||
|
|
||||||
For the top and overlay layers, the seat will always give
|
|
||||||
exclusive keyboard focus to the top-most layer which has keyboard
|
|
||||||
interactivity set to exclusive. If this layer contains multiple
|
|
||||||
surfaces with keyboard interactivity set to exclusive, the compositor
|
|
||||||
determines the one receiving keyboard events in an implementation-
|
|
||||||
defined manner. In this case, no guarantee is made when this surface
|
|
||||||
will receive keyboard focus (if ever).
|
|
||||||
|
|
||||||
For the bottom and background layers, the compositor is allowed to use
|
|
||||||
normal focus semantics.
|
|
||||||
|
|
||||||
This setting is mainly intended for applications that need to ensure
|
|
||||||
they receive all keyboard events, such as a lock screen or a password
|
|
||||||
prompt.
|
|
||||||
</description>
|
|
||||||
</entry>
|
|
||||||
<entry name="on_demand" value="2" since="4">
|
|
||||||
<description summary="request regular keyboard focus semantics">
|
|
||||||
This requests the compositor to allow this surface to be focused and
|
|
||||||
unfocused by the user in an implementation-defined manner. The user
|
|
||||||
should be able to unfocus this surface even regardless of the layer
|
|
||||||
it is on.
|
|
||||||
|
|
||||||
Typically, the compositor will want to use its normal mechanism to
|
|
||||||
manage keyboard focus between layer shell surfaces with this setting
|
|
||||||
and regular toplevels on the desktop layer (e.g. click to focus).
|
|
||||||
Nevertheless, it is possible for a compositor to require a special
|
|
||||||
interaction to focus or unfocus layer shell surfaces (e.g. requiring
|
|
||||||
a click even if focus follows the mouse normally, or providing a
|
|
||||||
keybinding to switch focus between layers).
|
|
||||||
|
|
||||||
This setting is mainly intended for desktop shell components (e.g.
|
|
||||||
panels) that allow keyboard interaction. Using this option can allow
|
|
||||||
implementing a desktop shell that can be fully usable without the
|
|
||||||
mouse.
|
|
||||||
</description>
|
|
||||||
</entry>
|
|
||||||
</enum>
|
|
||||||
|
|
||||||
<request name="set_keyboard_interactivity">
|
|
||||||
<description summary="requests keyboard events">
|
|
||||||
Set how keyboard events are delivered to this surface. By default,
|
|
||||||
layer shell surfaces do not receive keyboard events; this request can
|
|
||||||
be used to change this.
|
|
||||||
|
|
||||||
This setting is inherited by child surfaces set by the get_popup
|
|
||||||
request.
|
|
||||||
|
|
||||||
Layer surfaces receive pointer, touch, and tablet events normally. If
|
|
||||||
you do not want to receive them, set the input region on your surface
|
|
||||||
to an empty region.
|
|
||||||
|
|
||||||
Keyboard interactivity is double-buffered, see wl_surface.commit.
|
|
||||||
</description>
|
|
||||||
<arg name="keyboard_interactivity" type="uint" enum="keyboard_interactivity"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="get_popup">
|
|
||||||
<description summary="assign this layer_surface as an xdg_popup parent">
|
|
||||||
This assigns an xdg_popup's parent to this layer_surface. This popup
|
|
||||||
should have been created via xdg_surface::get_popup with the parent set
|
|
||||||
to NULL, and this request must be invoked before committing the popup's
|
|
||||||
initial state.
|
|
||||||
|
|
||||||
See the documentation of xdg_popup for more details about what an
|
|
||||||
xdg_popup is and how it is used.
|
|
||||||
</description>
|
|
||||||
<arg name="popup" type="object" interface="xdg_popup"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="ack_configure">
|
|
||||||
<description summary="ack a configure event">
|
|
||||||
When a configure event is received, if a client commits the
|
|
||||||
surface in response to the configure event, then the client
|
|
||||||
must make an ack_configure request sometime before the commit
|
|
||||||
request, passing along the serial of the configure event.
|
|
||||||
|
|
||||||
If the client receives multiple configure events before it
|
|
||||||
can respond to one, it only has to ack the last configure event.
|
|
||||||
|
|
||||||
A client is not required to commit immediately after sending
|
|
||||||
an ack_configure request - it may even ack_configure several times
|
|
||||||
before its next surface commit.
|
|
||||||
|
|
||||||
A client may send multiple ack_configure requests before committing, but
|
|
||||||
only the last request sent before a commit indicates which configure
|
|
||||||
event the client really is responding to.
|
|
||||||
</description>
|
|
||||||
<arg name="serial" type="uint" summary="the serial from the configure event"/>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<request name="destroy" type="destructor">
|
|
||||||
<description summary="destroy the layer_surface">
|
|
||||||
This request destroys the layer surface.
|
|
||||||
</description>
|
|
||||||
</request>
|
|
||||||
|
|
||||||
<event name="configure">
|
|
||||||
<description summary="suggest a surface change">
|
|
||||||
The configure event asks the client to resize its surface.
|
|
||||||
|
|
||||||
Clients should arrange their surface for the new states, and then send
|
|
||||||
an ack_configure request with the serial sent in this configure event at
|
|
||||||
some point before committing the new surface.
|
|
||||||
|
|
||||||
The client is free to dismiss all but the last configure event it
|
|
||||||
received.
|
|
||||||
|
|
||||||
The width and height arguments specify the size of the window in
|
|
||||||
surface-local coordinates.
|
|
||||||
|
|
||||||
The size is a hint, in the sense that the client is free to ignore it if
|
|
||||||
it doesn't resize, pick a smaller size (to satisfy aspect ratio or
|
|
||||||
resize in steps of NxM pixels). If the client picks a smaller size and
|
|
||||||
is anchored to two opposite anchors (e.g. 'top' and 'bottom'), the
|
|
||||||
surface will be centered on this axis.
|
|
||||||
|
|
||||||
If the width or height arguments are zero, it means the client should
|
|
||||||
decide its own window dimension.
|
|
||||||
</description>
|
|
||||||
<arg name="serial" type="uint"/>
|
|
||||||
<arg name="width" type="uint"/>
|
|
||||||
<arg name="height" type="uint"/>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<event name="closed">
|
|
||||||
<description summary="surface should be closed">
|
|
||||||
The closed event is sent by the compositor when the surface will no
|
|
||||||
longer be shown. The output may have been destroyed or the user may
|
|
||||||
have asked for it to be removed. Further changes to the surface will be
|
|
||||||
ignored. The client should destroy the resource after receiving this
|
|
||||||
event, and create a new surface if they so choose.
|
|
||||||
</description>
|
|
||||||
</event>
|
|
||||||
|
|
||||||
<enum name="error">
|
|
||||||
<entry name="invalid_surface_state" value="0" summary="provided surface state is invalid"/>
|
|
||||||
<entry name="invalid_size" value="1" summary="size is invalid"/>
|
|
||||||
<entry name="invalid_anchor" value="2" summary="anchor bitfield is invalid"/>
|
|
||||||
<entry name="invalid_keyboard_interactivity" value="3" summary="keyboard interactivity is invalid"/>
|
|
||||||
</enum>
|
|
||||||
|
|
||||||
<enum name="anchor" bitfield="true">
|
|
||||||
<entry name="top" value="1" summary="the top edge of the anchor rectangle"/>
|
|
||||||
<entry name="bottom" value="2" summary="the bottom edge of the anchor rectangle"/>
|
|
||||||
<entry name="left" value="4" summary="the left edge of the anchor rectangle"/>
|
|
||||||
<entry name="right" value="8" summary="the right edge of the anchor rectangle"/>
|
|
||||||
</enum>
|
|
||||||
|
|
||||||
<!-- Version 2 additions -->
|
|
||||||
|
|
||||||
<request name="set_layer" since="2">
|
|
||||||
<description summary="change the layer of the surface">
|
|
||||||
Change the layer that the surface is rendered on.
|
|
||||||
|
|
||||||
Layer is double-buffered, see wl_surface.commit.
|
|
||||||
</description>
|
|
||||||
<arg name="layer" type="uint" enum="zwlr_layer_shell_v1.layer" summary="layer to move this surface to"/>
|
|
||||||
</request>
|
|
||||||
</interface>
|
|
||||||
</protocol>
|
|
||||||
35
dwl/util.c
35
dwl/util.c
@@ -1,35 +0,0 @@
|
|||||||
/* See LICENSE.dwm file for copyright and license details. */
|
|
||||||
#include <stdarg.h>
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "util.h"
|
|
||||||
|
|
||||||
void
|
|
||||||
die(const char *fmt, ...) {
|
|
||||||
va_list ap;
|
|
||||||
|
|
||||||
va_start(ap, fmt);
|
|
||||||
vfprintf(stderr, fmt, ap);
|
|
||||||
va_end(ap);
|
|
||||||
|
|
||||||
if (fmt[0] && fmt[strlen(fmt)-1] == ':') {
|
|
||||||
fputc(' ', stderr);
|
|
||||||
perror(NULL);
|
|
||||||
} else {
|
|
||||||
fputc('\n', stderr);
|
|
||||||
}
|
|
||||||
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
void *
|
|
||||||
ecalloc(size_t nmemb, size_t size)
|
|
||||||
{
|
|
||||||
void *p;
|
|
||||||
|
|
||||||
if (!(p = calloc(nmemb, size)))
|
|
||||||
die("calloc:");
|
|
||||||
return p;
|
|
||||||
}
|
|
||||||
@@ -1,4 +0,0 @@
|
|||||||
/* See LICENSE.dwm file for copyright and license details. */
|
|
||||||
|
|
||||||
void die(const char *fmt, ...);
|
|
||||||
void *ecalloc(size_t nmemb, size_t size);
|
|
||||||
@@ -1,606 +0,0 @@
|
|||||||
/* Generated by wayland-scanner 1.22.0 */
|
|
||||||
|
|
||||||
#ifndef WLR_LAYER_SHELL_UNSTABLE_V1_SERVER_PROTOCOL_H
|
|
||||||
#define WLR_LAYER_SHELL_UNSTABLE_V1_SERVER_PROTOCOL_H
|
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
#include <stddef.h>
|
|
||||||
#include "wayland-server.h"
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
struct wl_client;
|
|
||||||
struct wl_resource;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @page page_wlr_layer_shell_unstable_v1 The wlr_layer_shell_unstable_v1 protocol
|
|
||||||
* @section page_ifaces_wlr_layer_shell_unstable_v1 Interfaces
|
|
||||||
* - @subpage page_iface_zwlr_layer_shell_v1 - create surfaces that are layers of the desktop
|
|
||||||
* - @subpage page_iface_zwlr_layer_surface_v1 - layer metadata interface
|
|
||||||
* @section page_copyright_wlr_layer_shell_unstable_v1 Copyright
|
|
||||||
* <pre>
|
|
||||||
*
|
|
||||||
* Copyright © 2017 Drew DeVault
|
|
||||||
*
|
|
||||||
* Permission to use, copy, modify, distribute, and sell this
|
|
||||||
* software and its documentation for any purpose is hereby granted
|
|
||||||
* without fee, provided that the above copyright notice appear in
|
|
||||||
* all copies and that both that copyright notice and this permission
|
|
||||||
* notice appear in supporting documentation, and that the name of
|
|
||||||
* the copyright holders not be used in advertising or publicity
|
|
||||||
* pertaining to distribution of the software without specific,
|
|
||||||
* written prior permission. The copyright holders make no
|
|
||||||
* representations about the suitability of this software for any
|
|
||||||
* purpose. It is provided "as is" without express or implied
|
|
||||||
* warranty.
|
|
||||||
*
|
|
||||||
* THE COPYRIGHT HOLDERS DISCLAIM ALL WARRANTIES WITH REGARD TO THIS
|
|
||||||
* SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
||||||
* FITNESS, IN NO EVENT SHALL THE COPYRIGHT HOLDERS BE LIABLE FOR ANY
|
|
||||||
* SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
||||||
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN
|
|
||||||
* AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
|
|
||||||
* ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
|
|
||||||
* THIS SOFTWARE.
|
|
||||||
* </pre>
|
|
||||||
*/
|
|
||||||
struct wl_output;
|
|
||||||
struct wl_surface;
|
|
||||||
struct xdg_popup;
|
|
||||||
struct zwlr_layer_shell_v1;
|
|
||||||
struct zwlr_layer_surface_v1;
|
|
||||||
|
|
||||||
#ifndef ZWLR_LAYER_SHELL_V1_INTERFACE
|
|
||||||
#define ZWLR_LAYER_SHELL_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zwlr_layer_shell_v1 zwlr_layer_shell_v1
|
|
||||||
* @section page_iface_zwlr_layer_shell_v1_desc Description
|
|
||||||
*
|
|
||||||
* Clients can use this interface to assign the surface_layer role to
|
|
||||||
* wl_surfaces. Such surfaces are assigned to a "layer" of the output and
|
|
||||||
* rendered with a defined z-depth respective to each other. They may also be
|
|
||||||
* anchored to the edges and corners of a screen and specify input handling
|
|
||||||
* semantics. This interface should be suitable for the implementation of
|
|
||||||
* many desktop shell components, and a broad number of other applications
|
|
||||||
* that interact with the desktop.
|
|
||||||
* @section page_iface_zwlr_layer_shell_v1_api API
|
|
||||||
* See @ref iface_zwlr_layer_shell_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zwlr_layer_shell_v1 The zwlr_layer_shell_v1 interface
|
|
||||||
*
|
|
||||||
* Clients can use this interface to assign the surface_layer role to
|
|
||||||
* wl_surfaces. Such surfaces are assigned to a "layer" of the output and
|
|
||||||
* rendered with a defined z-depth respective to each other. They may also be
|
|
||||||
* anchored to the edges and corners of a screen and specify input handling
|
|
||||||
* semantics. This interface should be suitable for the implementation of
|
|
||||||
* many desktop shell components, and a broad number of other applications
|
|
||||||
* that interact with the desktop.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zwlr_layer_shell_v1_interface;
|
|
||||||
#endif
|
|
||||||
#ifndef ZWLR_LAYER_SURFACE_V1_INTERFACE
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_INTERFACE
|
|
||||||
/**
|
|
||||||
* @page page_iface_zwlr_layer_surface_v1 zwlr_layer_surface_v1
|
|
||||||
* @section page_iface_zwlr_layer_surface_v1_desc Description
|
|
||||||
*
|
|
||||||
* An interface that may be implemented by a wl_surface, for surfaces that
|
|
||||||
* are designed to be rendered as a layer of a stacked desktop-like
|
|
||||||
* environment.
|
|
||||||
*
|
|
||||||
* Layer surface state (layer, size, anchor, exclusive zone,
|
|
||||||
* margin, interactivity) is double-buffered, and will be applied at the
|
|
||||||
* time wl_surface.commit of the corresponding wl_surface is called.
|
|
||||||
*
|
|
||||||
* Attaching a null buffer to a layer surface unmaps it.
|
|
||||||
*
|
|
||||||
* Unmapping a layer_surface means that the surface cannot be shown by the
|
|
||||||
* compositor until it is explicitly mapped again. The layer_surface
|
|
||||||
* returns to the state it had right after layer_shell.get_layer_surface.
|
|
||||||
* The client can re-map the surface by performing a commit without any
|
|
||||||
* buffer attached, waiting for a configure event and handling it as usual.
|
|
||||||
* @section page_iface_zwlr_layer_surface_v1_api API
|
|
||||||
* See @ref iface_zwlr_layer_surface_v1.
|
|
||||||
*/
|
|
||||||
/**
|
|
||||||
* @defgroup iface_zwlr_layer_surface_v1 The zwlr_layer_surface_v1 interface
|
|
||||||
*
|
|
||||||
* An interface that may be implemented by a wl_surface, for surfaces that
|
|
||||||
* are designed to be rendered as a layer of a stacked desktop-like
|
|
||||||
* environment.
|
|
||||||
*
|
|
||||||
* Layer surface state (layer, size, anchor, exclusive zone,
|
|
||||||
* margin, interactivity) is double-buffered, and will be applied at the
|
|
||||||
* time wl_surface.commit of the corresponding wl_surface is called.
|
|
||||||
*
|
|
||||||
* Attaching a null buffer to a layer surface unmaps it.
|
|
||||||
*
|
|
||||||
* Unmapping a layer_surface means that the surface cannot be shown by the
|
|
||||||
* compositor until it is explicitly mapped again. The layer_surface
|
|
||||||
* returns to the state it had right after layer_shell.get_layer_surface.
|
|
||||||
* The client can re-map the surface by performing a commit without any
|
|
||||||
* buffer attached, waiting for a configure event and handling it as usual.
|
|
||||||
*/
|
|
||||||
extern const struct wl_interface zwlr_layer_surface_v1_interface;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifndef ZWLR_LAYER_SHELL_V1_ERROR_ENUM
|
|
||||||
#define ZWLR_LAYER_SHELL_V1_ERROR_ENUM
|
|
||||||
enum zwlr_layer_shell_v1_error {
|
|
||||||
/**
|
|
||||||
* wl_surface has another role
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SHELL_V1_ERROR_ROLE = 0,
|
|
||||||
/**
|
|
||||||
* layer value is invalid
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SHELL_V1_ERROR_INVALID_LAYER = 1,
|
|
||||||
/**
|
|
||||||
* wl_surface has a buffer attached or committed
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SHELL_V1_ERROR_ALREADY_CONSTRUCTED = 2,
|
|
||||||
};
|
|
||||||
#endif /* ZWLR_LAYER_SHELL_V1_ERROR_ENUM */
|
|
||||||
|
|
||||||
#ifndef ZWLR_LAYER_SHELL_V1_LAYER_ENUM
|
|
||||||
#define ZWLR_LAYER_SHELL_V1_LAYER_ENUM
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_shell_v1
|
|
||||||
* available layers for surfaces
|
|
||||||
*
|
|
||||||
* These values indicate which layers a surface can be rendered in. They
|
|
||||||
* are ordered by z depth, bottom-most first. Traditional shell surfaces
|
|
||||||
* will typically be rendered between the bottom and top layers.
|
|
||||||
* Fullscreen shell surfaces are typically rendered at the top layer.
|
|
||||||
* Multiple surfaces can share a single layer, and ordering within a
|
|
||||||
* single layer is undefined.
|
|
||||||
*/
|
|
||||||
enum zwlr_layer_shell_v1_layer {
|
|
||||||
ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND = 0,
|
|
||||||
ZWLR_LAYER_SHELL_V1_LAYER_BOTTOM = 1,
|
|
||||||
ZWLR_LAYER_SHELL_V1_LAYER_TOP = 2,
|
|
||||||
ZWLR_LAYER_SHELL_V1_LAYER_OVERLAY = 3,
|
|
||||||
};
|
|
||||||
#endif /* ZWLR_LAYER_SHELL_V1_LAYER_ENUM */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_shell_v1
|
|
||||||
* @struct zwlr_layer_shell_v1_interface
|
|
||||||
*/
|
|
||||||
struct zwlr_layer_shell_v1_interface {
|
|
||||||
/**
|
|
||||||
* create a layer_surface from a surface
|
|
||||||
*
|
|
||||||
* Create a layer surface for an existing surface. This assigns
|
|
||||||
* the role of layer_surface, or raises a protocol error if another
|
|
||||||
* role is already assigned.
|
|
||||||
*
|
|
||||||
* Creating a layer surface from a wl_surface which has a buffer
|
|
||||||
* attached or committed is a client error, and any attempts by a
|
|
||||||
* client to attach or manipulate a buffer prior to the first
|
|
||||||
* layer_surface.configure call must also be treated as errors.
|
|
||||||
*
|
|
||||||
* After creating a layer_surface object and setting it up, the
|
|
||||||
* client must perform an initial commit without any buffer
|
|
||||||
* attached. The compositor will reply with a
|
|
||||||
* layer_surface.configure event. The client must acknowledge it
|
|
||||||
* and is then allowed to attach a buffer to map the surface.
|
|
||||||
*
|
|
||||||
* You may pass NULL for output to allow the compositor to decide
|
|
||||||
* which output to use. Generally this will be the one that the
|
|
||||||
* user most recently interacted with.
|
|
||||||
*
|
|
||||||
* Clients can specify a namespace that defines the purpose of the
|
|
||||||
* layer surface.
|
|
||||||
* @param layer layer to add this surface to
|
|
||||||
* @param namespace namespace for the layer surface
|
|
||||||
*/
|
|
||||||
void (*get_layer_surface)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t id,
|
|
||||||
struct wl_resource *surface,
|
|
||||||
struct wl_resource *output,
|
|
||||||
uint32_t layer,
|
|
||||||
const char *namespace);
|
|
||||||
/**
|
|
||||||
* destroy the layer_shell object
|
|
||||||
*
|
|
||||||
* This request indicates that the client will not use the
|
|
||||||
* layer_shell object any more. Objects that have been created
|
|
||||||
* through this instance are not affected.
|
|
||||||
* @since 3
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_shell_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SHELL_V1_GET_LAYER_SURFACE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_shell_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SHELL_V1_DESTROY_SINCE_VERSION 3
|
|
||||||
|
|
||||||
#ifndef ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_ENUM
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_ENUM
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
* types of keyboard interaction possible for a layer shell surface
|
|
||||||
*
|
|
||||||
* Types of keyboard interaction possible for layer shell surfaces. The
|
|
||||||
* rationale for this is twofold: (1) some applications are not interested
|
|
||||||
* in keyboard events and not allowing them to be focused can improve the
|
|
||||||
* desktop experience; (2) some applications will want to take exclusive
|
|
||||||
* keyboard focus.
|
|
||||||
*/
|
|
||||||
enum zwlr_layer_surface_v1_keyboard_interactivity {
|
|
||||||
/**
|
|
||||||
* no keyboard focus is possible
|
|
||||||
*
|
|
||||||
* This value indicates that this surface is not interested in
|
|
||||||
* keyboard events and the compositor should never assign it the
|
|
||||||
* keyboard focus.
|
|
||||||
*
|
|
||||||
* This is the default value, set for newly created layer shell
|
|
||||||
* surfaces.
|
|
||||||
*
|
|
||||||
* This is useful for e.g. desktop widgets that display information
|
|
||||||
* or only have interaction with non-keyboard input devices.
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_NONE = 0,
|
|
||||||
/**
|
|
||||||
* request exclusive keyboard focus
|
|
||||||
*
|
|
||||||
* Request exclusive keyboard focus if this surface is above the
|
|
||||||
* shell surface layer.
|
|
||||||
*
|
|
||||||
* For the top and overlay layers, the seat will always give
|
|
||||||
* exclusive keyboard focus to the top-most layer which has
|
|
||||||
* keyboard interactivity set to exclusive. If this layer contains
|
|
||||||
* multiple surfaces with keyboard interactivity set to exclusive,
|
|
||||||
* the compositor determines the one receiving keyboard events in
|
|
||||||
* an implementation- defined manner. In this case, no guarantee is
|
|
||||||
* made when this surface will receive keyboard focus (if ever).
|
|
||||||
*
|
|
||||||
* For the bottom and background layers, the compositor is allowed
|
|
||||||
* to use normal focus semantics.
|
|
||||||
*
|
|
||||||
* This setting is mainly intended for applications that need to
|
|
||||||
* ensure they receive all keyboard events, such as a lock screen
|
|
||||||
* or a password prompt.
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_EXCLUSIVE = 1,
|
|
||||||
/**
|
|
||||||
* request regular keyboard focus semantics
|
|
||||||
*
|
|
||||||
* This requests the compositor to allow this surface to be
|
|
||||||
* focused and unfocused by the user in an implementation-defined
|
|
||||||
* manner. The user should be able to unfocus this surface even
|
|
||||||
* regardless of the layer it is on.
|
|
||||||
*
|
|
||||||
* Typically, the compositor will want to use its normal mechanism
|
|
||||||
* to manage keyboard focus between layer shell surfaces with this
|
|
||||||
* setting and regular toplevels on the desktop layer (e.g. click
|
|
||||||
* to focus). Nevertheless, it is possible for a compositor to
|
|
||||||
* require a special interaction to focus or unfocus layer shell
|
|
||||||
* surfaces (e.g. requiring a click even if focus follows the mouse
|
|
||||||
* normally, or providing a keybinding to switch focus between
|
|
||||||
* layers).
|
|
||||||
*
|
|
||||||
* This setting is mainly intended for desktop shell components
|
|
||||||
* (e.g. panels) that allow keyboard interaction. Using this option
|
|
||||||
* can allow implementing a desktop shell that can be fully usable
|
|
||||||
* without the mouse.
|
|
||||||
* @since 4
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_ON_DEMAND = 2,
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_ON_DEMAND_SINCE_VERSION 4
|
|
||||||
#endif /* ZWLR_LAYER_SURFACE_V1_KEYBOARD_INTERACTIVITY_ENUM */
|
|
||||||
|
|
||||||
#ifndef ZWLR_LAYER_SURFACE_V1_ERROR_ENUM
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_ERROR_ENUM
|
|
||||||
enum zwlr_layer_surface_v1_error {
|
|
||||||
/**
|
|
||||||
* provided surface state is invalid
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ERROR_INVALID_SURFACE_STATE = 0,
|
|
||||||
/**
|
|
||||||
* size is invalid
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ERROR_INVALID_SIZE = 1,
|
|
||||||
/**
|
|
||||||
* anchor bitfield is invalid
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ERROR_INVALID_ANCHOR = 2,
|
|
||||||
/**
|
|
||||||
* keyboard interactivity is invalid
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ERROR_INVALID_KEYBOARD_INTERACTIVITY = 3,
|
|
||||||
};
|
|
||||||
#endif /* ZWLR_LAYER_SURFACE_V1_ERROR_ENUM */
|
|
||||||
|
|
||||||
#ifndef ZWLR_LAYER_SURFACE_V1_ANCHOR_ENUM
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_ANCHOR_ENUM
|
|
||||||
enum zwlr_layer_surface_v1_anchor {
|
|
||||||
/**
|
|
||||||
* the top edge of the anchor rectangle
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ANCHOR_TOP = 1,
|
|
||||||
/**
|
|
||||||
* the bottom edge of the anchor rectangle
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ANCHOR_BOTTOM = 2,
|
|
||||||
/**
|
|
||||||
* the left edge of the anchor rectangle
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ANCHOR_LEFT = 4,
|
|
||||||
/**
|
|
||||||
* the right edge of the anchor rectangle
|
|
||||||
*/
|
|
||||||
ZWLR_LAYER_SURFACE_V1_ANCHOR_RIGHT = 8,
|
|
||||||
};
|
|
||||||
#endif /* ZWLR_LAYER_SURFACE_V1_ANCHOR_ENUM */
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
* @struct zwlr_layer_surface_v1_interface
|
|
||||||
*/
|
|
||||||
struct zwlr_layer_surface_v1_interface {
|
|
||||||
/**
|
|
||||||
* sets the size of the surface
|
|
||||||
*
|
|
||||||
* Sets the size of the surface in surface-local coordinates. The
|
|
||||||
* compositor will display the surface centered with respect to its
|
|
||||||
* anchors.
|
|
||||||
*
|
|
||||||
* If you pass 0 for either value, the compositor will assign it
|
|
||||||
* and inform you of the assignment in the configure event. You
|
|
||||||
* must set your anchor to opposite edges in the dimensions you
|
|
||||||
* omit; not doing so is a protocol error. Both values are 0 by
|
|
||||||
* default.
|
|
||||||
*
|
|
||||||
* Size is double-buffered, see wl_surface.commit.
|
|
||||||
*/
|
|
||||||
void (*set_size)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t width,
|
|
||||||
uint32_t height);
|
|
||||||
/**
|
|
||||||
* configures the anchor point of the surface
|
|
||||||
*
|
|
||||||
* Requests that the compositor anchor the surface to the
|
|
||||||
* specified edges and corners. If two orthogonal edges are
|
|
||||||
* specified (e.g. 'top' and 'left'), then the anchor point will be
|
|
||||||
* the intersection of the edges (e.g. the top left corner of the
|
|
||||||
* output); otherwise the anchor point will be centered on that
|
|
||||||
* edge, or in the center if none is specified.
|
|
||||||
*
|
|
||||||
* Anchor is double-buffered, see wl_surface.commit.
|
|
||||||
*/
|
|
||||||
void (*set_anchor)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t anchor);
|
|
||||||
/**
|
|
||||||
* configures the exclusive geometry of this surface
|
|
||||||
*
|
|
||||||
* Requests that the compositor avoids occluding an area with
|
|
||||||
* other surfaces. The compositor's use of this information is
|
|
||||||
* implementation-dependent - do not assume that this region will
|
|
||||||
* not actually be occluded.
|
|
||||||
*
|
|
||||||
* A positive value is only meaningful if the surface is anchored
|
|
||||||
* to one edge or an edge and both perpendicular edges. If the
|
|
||||||
* surface is not anchored, anchored to only two perpendicular
|
|
||||||
* edges (a corner), anchored to only two parallel edges or
|
|
||||||
* anchored to all edges, a positive value will be treated the same
|
|
||||||
* as zero.
|
|
||||||
*
|
|
||||||
* A positive zone is the distance from the edge in surface-local
|
|
||||||
* coordinates to consider exclusive.
|
|
||||||
*
|
|
||||||
* Surfaces that do not wish to have an exclusive zone may instead
|
|
||||||
* specify how they should interact with surfaces that do. If set
|
|
||||||
* to zero, the surface indicates that it would like to be moved to
|
|
||||||
* avoid occluding surfaces with a positive exclusive zone. If set
|
|
||||||
* to -1, the surface indicates that it would not like to be moved
|
|
||||||
* to accommodate for other surfaces, and the compositor should
|
|
||||||
* extend it all the way to the edges it is anchored to.
|
|
||||||
*
|
|
||||||
* For example, a panel might set its exclusive zone to 10, so that
|
|
||||||
* maximized shell surfaces are not shown on top of it. A
|
|
||||||
* notification might set its exclusive zone to 0, so that it is
|
|
||||||
* moved to avoid occluding the panel, but shell surfaces are shown
|
|
||||||
* underneath it. A wallpaper or lock screen might set their
|
|
||||||
* exclusive zone to -1, so that they stretch below or over the
|
|
||||||
* panel.
|
|
||||||
*
|
|
||||||
* The default value is 0.
|
|
||||||
*
|
|
||||||
* Exclusive zone is double-buffered, see wl_surface.commit.
|
|
||||||
*/
|
|
||||||
void (*set_exclusive_zone)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
int32_t zone);
|
|
||||||
/**
|
|
||||||
* sets a margin from the anchor point
|
|
||||||
*
|
|
||||||
* Requests that the surface be placed some distance away from
|
|
||||||
* the anchor point on the output, in surface-local coordinates.
|
|
||||||
* Setting this value for edges you are not anchored to has no
|
|
||||||
* effect.
|
|
||||||
*
|
|
||||||
* The exclusive zone includes the margin.
|
|
||||||
*
|
|
||||||
* Margin is double-buffered, see wl_surface.commit.
|
|
||||||
*/
|
|
||||||
void (*set_margin)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
int32_t top,
|
|
||||||
int32_t right,
|
|
||||||
int32_t bottom,
|
|
||||||
int32_t left);
|
|
||||||
/**
|
|
||||||
* requests keyboard events
|
|
||||||
*
|
|
||||||
* Set how keyboard events are delivered to this surface. By
|
|
||||||
* default, layer shell surfaces do not receive keyboard events;
|
|
||||||
* this request can be used to change this.
|
|
||||||
*
|
|
||||||
* This setting is inherited by child surfaces set by the get_popup
|
|
||||||
* request.
|
|
||||||
*
|
|
||||||
* Layer surfaces receive pointer, touch, and tablet events
|
|
||||||
* normally. If you do not want to receive them, set the input
|
|
||||||
* region on your surface to an empty region.
|
|
||||||
*
|
|
||||||
* Keyboard interactivity is double-buffered, see
|
|
||||||
* wl_surface.commit.
|
|
||||||
*/
|
|
||||||
void (*set_keyboard_interactivity)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t keyboard_interactivity);
|
|
||||||
/**
|
|
||||||
* assign this layer_surface as an xdg_popup parent
|
|
||||||
*
|
|
||||||
* This assigns an xdg_popup's parent to this layer_surface. This
|
|
||||||
* popup should have been created via xdg_surface::get_popup with
|
|
||||||
* the parent set to NULL, and this request must be invoked before
|
|
||||||
* committing the popup's initial state.
|
|
||||||
*
|
|
||||||
* See the documentation of xdg_popup for more details about what
|
|
||||||
* an xdg_popup is and how it is used.
|
|
||||||
*/
|
|
||||||
void (*get_popup)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
struct wl_resource *popup);
|
|
||||||
/**
|
|
||||||
* ack a configure event
|
|
||||||
*
|
|
||||||
* When a configure event is received, if a client commits the
|
|
||||||
* surface in response to the configure event, then the client must
|
|
||||||
* make an ack_configure request sometime before the commit
|
|
||||||
* request, passing along the serial of the configure event.
|
|
||||||
*
|
|
||||||
* If the client receives multiple configure events before it can
|
|
||||||
* respond to one, it only has to ack the last configure event.
|
|
||||||
*
|
|
||||||
* A client is not required to commit immediately after sending an
|
|
||||||
* ack_configure request - it may even ack_configure several times
|
|
||||||
* before its next surface commit.
|
|
||||||
*
|
|
||||||
* A client may send multiple ack_configure requests before
|
|
||||||
* committing, but only the last request sent before a commit
|
|
||||||
* indicates which configure event the client really is responding
|
|
||||||
* to.
|
|
||||||
* @param serial the serial from the configure event
|
|
||||||
*/
|
|
||||||
void (*ack_configure)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t serial);
|
|
||||||
/**
|
|
||||||
* destroy the layer_surface
|
|
||||||
*
|
|
||||||
* This request destroys the layer surface.
|
|
||||||
*/
|
|
||||||
void (*destroy)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource);
|
|
||||||
/**
|
|
||||||
* change the layer of the surface
|
|
||||||
*
|
|
||||||
* Change the layer that the surface is rendered on.
|
|
||||||
*
|
|
||||||
* Layer is double-buffered, see wl_surface.commit.
|
|
||||||
* @param layer layer to move this surface to
|
|
||||||
* @since 2
|
|
||||||
*/
|
|
||||||
void (*set_layer)(struct wl_client *client,
|
|
||||||
struct wl_resource *resource,
|
|
||||||
uint32_t layer);
|
|
||||||
};
|
|
||||||
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_CONFIGURE 0
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_CLOSED 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_CONFIGURE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_CLOSED_SINCE_VERSION 1
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_SET_SIZE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_SET_ANCHOR_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_SET_EXCLUSIVE_ZONE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_SET_MARGIN_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_SET_KEYBOARD_INTERACTIVITY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_GET_POPUP_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_ACK_CONFIGURE_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_DESTROY_SINCE_VERSION 1
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
*/
|
|
||||||
#define ZWLR_LAYER_SURFACE_V1_SET_LAYER_SINCE_VERSION 2
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
* Sends an configure event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zwlr_layer_surface_v1_send_configure(struct wl_resource *resource_, uint32_t serial, uint32_t width, uint32_t height)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZWLR_LAYER_SURFACE_V1_CONFIGURE, serial, width, height);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @ingroup iface_zwlr_layer_surface_v1
|
|
||||||
* Sends an closed event to the client owning the resource.
|
|
||||||
* @param resource_ The client's resource
|
|
||||||
*/
|
|
||||||
static inline void
|
|
||||||
zwlr_layer_surface_v1_send_closed(struct wl_resource *resource_)
|
|
||||||
{
|
|
||||||
wl_resource_post_event(resource_, ZWLR_LAYER_SURFACE_V1_CLOSED);
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif
|
|
||||||
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user