mirror of
https://github.com/swaywm/sway.git
synced 2024-11-24 08:51:27 +00:00
07042486c3
To query whether a container is sticky, checking `con->is_sticky` is insufficient. `container_is_floating_or_child` must also return true; this led to a lot of repetition. This commit introduces `container_is_sticky[_or_child]` functions, and switches all stickiness checks to use them. (Including ones where the container is already known to be floating, for consistency.)
50 lines
1.5 KiB
C
50 lines
1.5 KiB
C
#include <string.h>
|
|
#include <strings.h>
|
|
#include "sway/commands.h"
|
|
#include "sway/input/seat.h"
|
|
#include "sway/ipc-server.h"
|
|
#include "sway/output.h"
|
|
#include "sway/tree/arrange.h"
|
|
#include "sway/tree/container.h"
|
|
#include "sway/tree/view.h"
|
|
#include "sway/tree/workspace.h"
|
|
#include "list.h"
|
|
#include "log.h"
|
|
#include "util.h"
|
|
|
|
struct cmd_results *cmd_sticky(int argc, char **argv) {
|
|
struct cmd_results *error = NULL;
|
|
if ((error = checkarg(argc, "sticky", EXPECTED_EQUAL_TO, 1))) {
|
|
return error;
|
|
}
|
|
struct sway_container *container = config->handler_context.container;
|
|
|
|
if (container == NULL) {
|
|
return cmd_results_new(CMD_FAILURE, "No current container");
|
|
};
|
|
|
|
container->is_sticky = parse_boolean(argv[0], container->is_sticky);
|
|
|
|
if (container_is_sticky_or_child(container) &&
|
|
!container_is_scratchpad_hidden(container)) {
|
|
// move container to active workspace
|
|
struct sway_workspace *active_workspace =
|
|
output_get_active_workspace(container->workspace->output);
|
|
if (!sway_assert(active_workspace,
|
|
"Expected output to have a workspace")) {
|
|
return cmd_results_new(CMD_FAILURE,
|
|
"Expected output to have a workspace");
|
|
}
|
|
if (container->workspace != active_workspace) {
|
|
struct sway_workspace *old_workspace = container->workspace;
|
|
container_detach(container);
|
|
workspace_add_floating(active_workspace, container);
|
|
container_handle_fullscreen_reparent(container);
|
|
arrange_workspace(active_workspace);
|
|
workspace_consider_destroy(old_workspace);
|
|
}
|
|
}
|
|
|
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
|
}
|