mirror of
https://github.com/hyprwm/wlroots-hyprland.git
synced 2025-01-22 22:49:48 +01:00
examples: add fullscreening to foreign-toplevel.c
This commit is contained in:
parent
8cc0859814
commit
22dd7d3731
1 changed files with 28 additions and 6 deletions
|
@ -7,6 +7,8 @@
|
|||
#include <wayland-client.h>
|
||||
#include "wlr-foreign-toplevel-management-unstable-v1-client-protocol.h"
|
||||
|
||||
#define WLR_FOREIGN_TOPLEVEL_MANAGEMENT_VERSION 2
|
||||
|
||||
/**
|
||||
* Usage:
|
||||
* 1. foreign-toplevel
|
||||
|
@ -29,10 +31,11 @@
|
|||
*/
|
||||
|
||||
enum toplevel_state_field {
|
||||
TOPLEVEL_STATE_MAXIMIZED = 1,
|
||||
TOPLEVEL_STATE_MINIMIZED = 2,
|
||||
TOPLEVEL_STATE_ACTIVATED = 4,
|
||||
TOPLEVEL_STATE_INVALID = 8,
|
||||
TOPLEVEL_STATE_MAXIMIZED = (1 << 0),
|
||||
TOPLEVEL_STATE_MINIMIZED = (1 << 1),
|
||||
TOPLEVEL_STATE_ACTIVATED = (1 << 2),
|
||||
TOPLEVEL_STATE_FULLSCREEN = (1 << 3),
|
||||
TOPLEVEL_STATE_INVALID = (1 << 4),
|
||||
};
|
||||
|
||||
struct toplevel_state {
|
||||
|
@ -102,6 +105,9 @@ static void print_toplevel_state(struct toplevel_v1 *toplevel, bool print_endl)
|
|||
} else {
|
||||
printf(" inactive");
|
||||
}
|
||||
if (toplevel->current.state & TOPLEVEL_STATE_FULLSCREEN) {
|
||||
printf(" fullscreen");
|
||||
}
|
||||
|
||||
if (print_endl) {
|
||||
printf("\n");
|
||||
|
@ -152,6 +158,8 @@ static uint32_t array_to_state(struct wl_array *array) {
|
|||
state |= TOPLEVEL_STATE_MINIMIZED;
|
||||
if (*entry == ZWLR_FOREIGN_TOPLEVEL_HANDLE_V1_STATE_ACTIVATED)
|
||||
state |= TOPLEVEL_STATE_ACTIVATED;
|
||||
if (*entry == ZWLR_FOREIGN_TOPLEVEL_HANDLE_V1_STATE_FULLSCREEN)
|
||||
state |= TOPLEVEL_STATE_FULLSCREEN;
|
||||
}
|
||||
|
||||
return state;
|
||||
|
@ -236,7 +244,8 @@ static void handle_global(void *data, struct wl_registry *registry,
|
|||
} else if (strcmp(interface,
|
||||
zwlr_foreign_toplevel_manager_v1_interface.name) == 0) {
|
||||
toplevel_manager = wl_registry_bind(registry, name,
|
||||
&zwlr_foreign_toplevel_manager_v1_interface, 1);
|
||||
&zwlr_foreign_toplevel_manager_v1_interface,
|
||||
WLR_FOREIGN_TOPLEVEL_MANAGEMENT_VERSION);
|
||||
|
||||
wl_list_init(&toplevel_list);
|
||||
zwlr_foreign_toplevel_manager_v1_add_listener(toplevel_manager,
|
||||
|
@ -278,11 +287,12 @@ int main(int argc, char **argv) {
|
|||
int focus_id = -1, close_id = -1;
|
||||
int maximize_id = -1, unmaximize_id = -1;
|
||||
int minimize_id = -1, restore_id = -1;
|
||||
int fullscreen_id = -1, unfullscreen_id = -1;
|
||||
int one_shot = 1;
|
||||
int c;
|
||||
|
||||
// TODO maybe print usage with -h?
|
||||
while ((c = getopt(argc, argv, "f:a:u:i:r:c:m")) != -1) {
|
||||
while ((c = getopt(argc, argv, "f:a:u:i:r:c:s:S:m")) != -1) {
|
||||
switch (c) {
|
||||
case 'f':
|
||||
focus_id = atoi(optarg);
|
||||
|
@ -302,6 +312,12 @@ int main(int argc, char **argv) {
|
|||
case 'c':
|
||||
close_id = atoi(optarg);
|
||||
break;
|
||||
case 's':
|
||||
fullscreen_id = atoi(optarg);
|
||||
break;
|
||||
case 'S':
|
||||
unfullscreen_id = atoi(optarg);
|
||||
break;
|
||||
case 'm':
|
||||
one_shot = 0;
|
||||
break;
|
||||
|
@ -342,6 +358,12 @@ int main(int argc, char **argv) {
|
|||
if ((toplevel = toplevel_by_id_or_bail(restore_id))) {
|
||||
zwlr_foreign_toplevel_handle_v1_unset_minimized(toplevel->zwlr_toplevel);
|
||||
}
|
||||
if ((toplevel = toplevel_by_id_or_bail(fullscreen_id))) {
|
||||
zwlr_foreign_toplevel_handle_v1_set_fullscreen(toplevel->zwlr_toplevel, NULL);
|
||||
}
|
||||
if ((toplevel = toplevel_by_id_or_bail(unfullscreen_id))) {
|
||||
zwlr_foreign_toplevel_handle_v1_unset_fullscreen(toplevel->zwlr_toplevel);
|
||||
}
|
||||
if ((toplevel = toplevel_by_id_or_bail(close_id))) {
|
||||
zwlr_foreign_toplevel_handle_v1_close(toplevel->zwlr_toplevel);
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue