diff options
author | S. Christoffer Eliesen <[email protected]> | 2015-11-19 16:37:48 +0100 |
---|---|---|
committer | S. Christoffer Eliesen <[email protected]> | 2015-11-22 21:17:36 +0100 |
commit | a0c5a0bb30af3cc132715e60cf3d87a77f88a095 (patch) | |
tree | 07d8e6ccf5aa61fd59135287f18f7d218c64cde1 /sway/config.c | |
parent | 9ce5d635f1f3d7e3e8fa0e2e028579285d23f0fc (diff) |
cmd_bindsym: Detect/handle duplicates.
Also replace `bindsym_sort` with function `sway_binding_cmp` that takes
all data into account when comparing.
Diffstat (limited to 'sway/config.c')
-rw-r--r-- | sway/config.c | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/sway/config.c b/sway/config.c index 2fceb6e2..d70c016a 100644 --- a/sway/config.c +++ b/sway/config.c @@ -383,3 +383,52 @@ int workspace_output_cmp_workspace(const void *a, const void *b) { const struct workspace_output *wsa = a, *wsb = b; return lenient_strcmp(wsa->workspace, wsb->workspace); } + +int sway_binding_cmp_keys(const void *a, const void *b) { + const struct sway_binding *binda = a, *bindb = b; + + if (binda->modifiers > bindb->modifiers) { + return 1; + } else if (binda->modifiers < bindb->modifiers) { + return -1; + } + + if (binda->keys->length > bindb->keys->length) { + return 1; + } else if (binda->keys->length < bindb->keys->length) { + return -1; + } + + for (int i = 0; i < binda->keys->length; i++) { + xkb_keysym_t *ka = binda->keys->items[i], + *kb = bindb->keys->items[i]; + if (*ka > *kb) { + return 1; + } else if (*ka < *kb) { + return -1; + } + } + return 0; +} + +int sway_binding_cmp(const void *a, const void *b) { + int cmp = 0; + if ((cmp = sway_binding_cmp_keys(a, b)) != 0) { + return cmp; + } + const struct sway_binding *binda = a, *bindb = b; + return lenient_strcmp(binda->command, bindb->command); +} + +void free_sway_binding(struct sway_binding *binding) { + if (binding->keys) { + for (int i = 0; i < binding->keys->length; i++) { + free(binding->keys->items[i]); + } + list_free(binding->keys); + } + if (binding->command) { + free(binding->command); + } + free(binding); +} |