mirror of
https://github.com/swaywm/sway.git
synced 2025-01-09 05:46:29 +01:00
2a684cad5f
Patch tested by compiling with `__attribute__ ((format (printf, 2, 3)))` applied to `cmd_results_new`. String usage constants have been converted from pointers to arrays when encountered. General handler format strings were sometimes modified to include the old input string, especially for unknown command errors.
42 lines
1.4 KiB
C
42 lines
1.4 KiB
C
#include "log.h"
|
|
#include "sway/commands.h"
|
|
#include "sway/config.h"
|
|
#include "sway/tree/arrange.h"
|
|
#include "sway/tree/container.h"
|
|
#include "sway/tree/view.h"
|
|
#include "sway/tree/workspace.h"
|
|
#include "util.h"
|
|
|
|
struct cmd_results *cmd_fullscreen(int argc, char **argv) {
|
|
struct cmd_results *error = NULL;
|
|
if ((error = checkarg(argc, "fullscreen", EXPECTED_AT_MOST, 1))) {
|
|
return error;
|
|
}
|
|
if (!root->outputs->length) {
|
|
return cmd_results_new(CMD_FAILURE,
|
|
"Can't run this command while there's no outputs connected.");
|
|
}
|
|
struct sway_node *node = config->handler_context.node;
|
|
struct sway_container *container = config->handler_context.container;
|
|
struct sway_workspace *workspace = config->handler_context.workspace;
|
|
if (node->type == N_WORKSPACE && workspace->tiling->length == 0) {
|
|
return cmd_results_new(CMD_FAILURE,
|
|
"Can't fullscreen an empty workspace");
|
|
}
|
|
if (node->type == N_WORKSPACE) {
|
|
// Wrap the workspace's children in a container so we can fullscreen it
|
|
container = workspace_wrap_children(workspace);
|
|
workspace->layout = L_HORIZ;
|
|
seat_set_focus_container(config->handler_context.seat, container);
|
|
}
|
|
bool enable = !container->is_fullscreen;
|
|
|
|
if (argc) {
|
|
enable = parse_boolean(argv[0], container->is_fullscreen);
|
|
}
|
|
|
|
container_set_fullscreen(container, enable);
|
|
arrange_workspace(workspace);
|
|
|
|
return cmd_results_new(CMD_SUCCESS, NULL);
|
|
}
|