diff options
Diffstat (limited to 'sway/commands')
-rw-r--r-- | sway/commands/shadow_blur_radius.c | 25 | ||||
-rw-r--r-- | sway/commands/shadow_color.c | 25 | ||||
-rw-r--r-- | sway/commands/shadows.c | 31 |
3 files changed, 81 insertions, 0 deletions
diff --git a/sway/commands/shadow_blur_radius.c b/sway/commands/shadow_blur_radius.c new file mode 100644 index 00000000..036341f8 --- /dev/null +++ b/sway/commands/shadow_blur_radius.c @@ -0,0 +1,25 @@ +#include <string.h> +#include "sway/commands.h" +#include "sway/config.h" +#include "sway/tree/arrange.h" +#include "sway/tree/container.h" +#include "log.h" + +struct cmd_results *cmd_shadow_blur_radius(int argc, char **argv) { + struct cmd_results *error = NULL; + if ((error = checkarg(argc, "shadow_blur_radius", EXPECTED_EQUAL_TO, 1))) { + return error; + } + + char *inv; + int value = strtol(argv[0], &inv, 10); + if (*inv != '\0' || value < 0 || value > 99) { + return cmd_results_new(CMD_FAILURE, "Invalid size specified"); + } + + config->shadow_blur_sigma = value; + + arrange_root(); + + return cmd_results_new(CMD_SUCCESS, NULL); +} diff --git a/sway/commands/shadow_color.c b/sway/commands/shadow_color.c new file mode 100644 index 00000000..02952bdd --- /dev/null +++ b/sway/commands/shadow_color.c @@ -0,0 +1,25 @@ +#include "log.h" +#include "sway/commands.h" +#include "sway/config.h" +#include "sway/output.h" +#include "sway/tree/arrange.h" +#include "sway/tree/container.h" +#include "util.h" + +struct cmd_results *cmd_shadow_color(int argc, char **argv) { + struct cmd_results *error = NULL; + if ((error = checkarg(argc, "shadow_color", EXPECTED_AT_LEAST, 1))) { + return error; + } + + uint32_t color; + if (!parse_color(argv[0], &color)) { + return cmd_results_new(CMD_INVALID, "Invalid %s color %s", + "shadow_color", argv[0]); + } + color_to_rgba(config->shadow_color, color); + + arrange_root(); + + return cmd_results_new(CMD_SUCCESS, NULL); +} diff --git a/sway/commands/shadows.c b/sway/commands/shadows.c new file mode 100644 index 00000000..2b57b2e6 --- /dev/null +++ b/sway/commands/shadows.c @@ -0,0 +1,31 @@ +#include <string.h> +#include "sway/commands.h" +#include "sway/config.h" +#include "sway/tree/arrange.h" +#include "sway/tree/view.h" +#include "sway/tree/container.h" +#include "log.h" +#include "stringop.h" +#include "util.h" + +struct cmd_results *cmd_shadows(int argc, char **argv) { + struct cmd_results *error = checkarg(argc, "shadows", EXPECTED_AT_LEAST, 1); + + if (error) { + return error; + } + + struct sway_container *con = config->handler_context.container; + + bool result = parse_boolean(argv[0], config->shadow_enabled); + if (con == NULL) { + config->shadow_enabled = result; + } else { + con->shadow_enabled = result; + container_damage_whole(con); + } + + arrange_root(); + + return cmd_results_new(CMD_SUCCESS, NULL); +} |