diff options
| author | Tony Crisci <tony@dubstepdish.com> | 2018-02-14 16:47:23 -0500 | 
|---|---|---|
| committer | Tony Crisci <tony@dubstepdish.com> | 2018-02-14 16:47:23 -0500 | 
| commit | 52670c636cf5115560ce6d20e2aaab1d55c49d0b (patch) | |
| tree | ccbd3fd4722758c5f5d7fb557f1c719cd51082aa /sway | |
| parent | 780d9fe1e3ee051a4d9eb08d1c049e19d72c1d6a (diff) | |
| download | sway-52670c636cf5115560ce6d20e2aaab1d55c49d0b.tar.xz | |
basic focus (without direction)
Diffstat (limited to 'sway')
| -rw-r--r-- | sway/commands.c | 1 | ||||
| -rw-r--r-- | sway/commands/focus.c | 32 | ||||
| -rw-r--r-- | sway/ipc-server.c | 1 | ||||
| -rw-r--r-- | sway/meson.build | 1 | 
4 files changed, 35 insertions, 0 deletions
| diff --git a/sway/commands.c b/sway/commands.c index d8d29a1c..bc2a85d7 100644 --- a/sway/commands.c +++ b/sway/commands.c @@ -132,6 +132,7 @@ static struct cmd_handler handlers[] = {  	{ "exec", cmd_exec },  	{ "exec_always", cmd_exec_always },  	{ "exit", cmd_exit }, +	{ "focus", cmd_focus },  	{ "include", cmd_include },  	{ "input", cmd_input },  	{ "kill", cmd_kill }, diff --git a/sway/commands/focus.c b/sway/commands/focus.c new file mode 100644 index 00000000..5286851f --- /dev/null +++ b/sway/commands/focus.c @@ -0,0 +1,32 @@ +#include <wlr/util/log.h> +#include "log.h" +#include "sway/input/input-manager.h" +#include "sway/input/seat.h" +#include "sway/view.h" +#include "sway/commands.h" + +struct cmd_results *cmd_focus(int argc, char **argv) { +	swayc_t *con = config->handler_context.current_container; +	struct sway_seat *seat = config->handler_context.seat; + +	if (!sway_assert(seat, "'focus' command called without seat context")) { +		return cmd_results_new(CMD_FAILURE, "focus", +			"Command 'focus' called without seat context (this is a bug in sway)"); +	} + +	if (config->reading) { +		return cmd_results_new(CMD_FAILURE, "focus", +			"Command 'focus' cannot be used in the config file"); +	} +	if (con == NULL) { +		wlr_log(L_DEBUG, "no container to focus"); +		return cmd_results_new(CMD_SUCCESS, NULL, NULL); +	} + +	if (argc == 0) { +		sway_seat_set_focus(seat, con); +		return cmd_results_new(CMD_SUCCESS, NULL, NULL); +	} + +	return cmd_results_new(CMD_SUCCESS, NULL, NULL); +} diff --git a/sway/ipc-server.c b/sway/ipc-server.c index a16a2b80..ee259c99 100644 --- a/sway/ipc-server.c +++ b/sway/ipc-server.c @@ -336,6 +336,7 @@ void ipc_client_handle_command(struct ipc_client *client) {  	case IPC_COMMAND:  	{  		config_clear_handler_context(config); +		config->handler_context.seat = input_manager_current_seat(input_manager);  		struct cmd_results *results = handle_command(buf);  		const char *json = cmd_results_to_json(results);  		char reply[256]; diff --git a/sway/meson.build b/sway/meson.build index 271d4a99..8d5a97d2 100644 --- a/sway/meson.build +++ b/sway/meson.build @@ -10,6 +10,7 @@ sway_sources = files(  	'commands/exit.c',  	'commands/exec.c',  	'commands/exec_always.c', +	'commands/focus.c',  	'commands/kill.c',  	'commands/include.c',  	'commands/input.c', | 
