minimal size and formatting
This commit is contained in:
+13
-16
@@ -1,6 +1,7 @@
|
||||
#include <stdlib.h>
|
||||
|
||||
#include <wayland-server-core.h>
|
||||
#include <wlr/util/log.h>
|
||||
|
||||
#include "types.h"
|
||||
#include "xdg-decoration.h"
|
||||
@@ -11,13 +12,16 @@ void xdg_toplevel_commit(struct wl_listener *listener, void *data)
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, commit);
|
||||
|
||||
if (toplevel->xdg_toplevel->base->initial_commit) {
|
||||
int bw = ABSINTHE_BORDER_WIDTH;
|
||||
int32_t cw = toplevel->xdg_toplevel->current.min_width;
|
||||
int32_t ch = toplevel->xdg_toplevel->current.min_height;
|
||||
|
||||
absinthe_toplevel_set_size(toplevel, toplevel->geometry.width - 2 * bw, toplevel->geometry.height - 2 * bw);
|
||||
int32_t w = MAX(cw, ABSINTHE_WINDOW_MIN_WIDTH);
|
||||
int32_t h = MAX(ch, ABSINTHE_WINDOW_MIN_HEIGHT);
|
||||
|
||||
absinthe_toplevel_set_size(toplevel, w, h);
|
||||
|
||||
if (toplevel->decoration) {
|
||||
if (toplevel->decoration)
|
||||
xdg_decoration_request_mode(&toplevel->decoration_request_mode, toplevel->decoration);
|
||||
}
|
||||
} else {
|
||||
absinthe_toplevel_set_position(toplevel, toplevel->geometry.x, toplevel->geometry.y);
|
||||
absinthe_toplevel_update_borders_geometry(toplevel);
|
||||
@@ -34,11 +38,8 @@ void xdg_toplevel_map(struct wl_listener *listener, void *data)
|
||||
toplevel->border[i]->node.data = toplevel;
|
||||
}
|
||||
|
||||
int bw = ABSINTHE_BORDER_WIDTH;
|
||||
|
||||
absinthe_toplevel_set_size(toplevel, toplevel->geometry.width - 2 * bw, toplevel->geometry.height - 2 * bw);
|
||||
|
||||
absinthe_toplevel_set_border_color(toplevel, bordercolor);
|
||||
absinthe_toplevel_update_borders_geometry(toplevel);
|
||||
|
||||
wl_list_insert(&toplevel->server->toplevels, &toplevel->link);
|
||||
}
|
||||
@@ -69,31 +70,27 @@ void xdg_toplevel_destroy(struct wl_listener *listener, void *data)
|
||||
void xdg_toplevel_request_move(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, request_maximize);
|
||||
if (toplevel->xdg_toplevel->base->initialized) {
|
||||
if (toplevel->xdg_toplevel->base->initialized)
|
||||
wlr_xdg_surface_schedule_configure(toplevel->xdg_toplevel->base);
|
||||
}
|
||||
}
|
||||
|
||||
void xdg_toplevel_request_resize(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, request_maximize);
|
||||
if (toplevel->xdg_toplevel->base->initialized) {
|
||||
if (toplevel->xdg_toplevel->base->initialized)
|
||||
wlr_xdg_surface_schedule_configure(toplevel->xdg_toplevel->base);
|
||||
}
|
||||
}
|
||||
|
||||
void xdg_toplevel_request_maximize(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, request_maximize);
|
||||
if (toplevel->xdg_toplevel->base->initialized) {
|
||||
if (toplevel->xdg_toplevel->base->initialized)
|
||||
wlr_xdg_surface_schedule_configure(toplevel->xdg_toplevel->base);
|
||||
}
|
||||
}
|
||||
|
||||
void xdg_toplevel_request_fullscreen(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, request_fullscreen);
|
||||
if (toplevel->xdg_toplevel->base->initialized) {
|
||||
if (toplevel->xdg_toplevel->base->initialized)
|
||||
wlr_xdg_surface_schedule_configure(toplevel->xdg_toplevel->base);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user