aboutsummaryrefslogtreecommitdiff
path: root/sway
diff options
context:
space:
mode:
authorRyan Dwyer <ryandwyer1@gmail.com>2018-09-01 11:13:48 +1000
committerRyan Dwyer <ryandwyer1@gmail.com>2018-09-01 11:17:15 +1000
commitebe65a4d481341d38b99e8fb36e66832888bc085 (patch)
treec88027b2dc43606bc3601a5b18f8e719553299cb /sway
parent1f1b1b34d6398d463658317dea06f640482f3caa (diff)
Fix crash on reload
If sway is reloaded using a bindsym which has multiple commands, it failed to detect the reload command, didn't create a duplicate of the binding and would crash because the reload command frees the bindings. For example: mode system { bindsym r reload, mode default } In this example, the binding->command is "reload, mode default". Fixes #2545
Diffstat (limited to 'sway')
-rw-r--r--sway/commands/bind.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/sway/commands/bind.c b/sway/commands/bind.c
index 8270b958..e73b0aea 100644
--- a/sway/commands/bind.c
+++ b/sway/commands/bind.c
@@ -310,7 +310,7 @@ void seat_execute_command(struct sway_seat *seat, struct sway_binding *binding)
bool reload = false;
// if this is a reload command we need to make a duplicate of the
// binding since it will be gone after the reload has completed.
- if (strcasecmp(binding->command, "reload") == 0) {
+ if (strncasecmp(binding->command, "reload", 6) == 0) {
reload = true;
binding_copy = sway_binding_dup(binding);
if (!binding_copy) {