mirror of
https://github.com/labwc/labwc.git
synced 2026-02-23 01:40:18 -05:00
Add simple foreign toplevel implementation
This commit is contained in:
parent
7dc4ae36ca
commit
042ea266a5
7 changed files with 91 additions and 2 deletions
25
src/xdg.c
25
src/xdg.c
|
|
@ -91,6 +91,9 @@ static void
|
|||
handle_destroy(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct view *view = wl_container_of(listener, view, destroy);
|
||||
if (view->toplevel_handle) {
|
||||
wlr_foreign_toplevel_handle_v1_destroy(view->toplevel_handle);
|
||||
}
|
||||
wl_list_remove(&view->link);
|
||||
ssd_destroy(view);
|
||||
free(view);
|
||||
|
|
@ -136,6 +139,14 @@ handle_request_maximize(struct wl_listener *listener, void *data)
|
|||
|
||||
}
|
||||
|
||||
static void
|
||||
handle_set_title(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct view *view = wl_container_of(listener, view, set_title);
|
||||
assert(view);
|
||||
view_update_title(view);
|
||||
}
|
||||
|
||||
static void
|
||||
xdg_toplevel_view_configure(struct view *view, struct wlr_box geo)
|
||||
{
|
||||
|
|
@ -248,6 +259,15 @@ position_xdg_toplevel_view(struct view *view)
|
|||
view->y += view->margin.top - view->padding.top;
|
||||
}
|
||||
|
||||
static const char *
|
||||
xdg_toplevel_view_get_string_prop(struct view *view, const char *prop)
|
||||
{
|
||||
if (!strcmp(prop, "title")) {
|
||||
return view->xdg_surface->toplevel->title;
|
||||
}
|
||||
return "none";
|
||||
}
|
||||
|
||||
static void
|
||||
xdg_toplevel_view_map(struct view *view)
|
||||
{
|
||||
|
|
@ -260,6 +280,8 @@ xdg_toplevel_view_map(struct view *view)
|
|||
*/
|
||||
view_maximize(view, false);
|
||||
|
||||
foreign_toplevel_handle_create(view);
|
||||
|
||||
view->ssd.enabled = has_ssd(view);
|
||||
if (view->ssd.enabled) {
|
||||
view->margin = ssd_thickness(view);
|
||||
|
|
@ -308,6 +330,7 @@ static const struct view_impl xdg_toplevel_view_impl = {
|
|||
.close = xdg_toplevel_view_close,
|
||||
.for_each_popup_surface = xdg_toplevel_view_for_each_popup_surface,
|
||||
.for_each_surface = xdg_toplevel_view_for_each_surface,
|
||||
.get_string_prop = xdg_toplevel_view_get_string_prop,
|
||||
.map = xdg_toplevel_view_map,
|
||||
.move = xdg_toplevel_view_move,
|
||||
.unmap = xdg_toplevel_view_unmap,
|
||||
|
|
@ -349,6 +372,8 @@ xdg_surface_new(struct wl_listener *listener, void *data)
|
|||
wl_signal_add(&toplevel->events.request_resize, &view->request_resize);
|
||||
view->request_maximize.notify = handle_request_maximize;
|
||||
wl_signal_add(&toplevel->events.request_maximize, &view->request_maximize);
|
||||
view->set_title.notify = handle_set_title;
|
||||
wl_signal_add(&toplevel->events.set_title, &view->set_title);
|
||||
|
||||
wl_list_insert(&server->views, &view->link);
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue