mirror of
https://github.com/swaywm/sway.git
synced 2024-12-01 19:06:38 +00:00
bar_cmd_modifier: add support for none
sway-bar(5) documents `modifier none`, which comes from i3. This implements the functionality for `modifier none` since it was not previously implemented. The bar modifier toggles visibility of the bar when the bar mode is set to hide. When the bar modifier is set to `none`, the ability to toggle visibility of the bar will be disabled.
This commit is contained in:
parent
32f790bd15
commit
4339ba6424
|
@ -15,11 +15,17 @@ struct cmd_results *bar_cmd_modifier(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t mod = 0;
|
uint32_t mod = 0;
|
||||||
|
if (strcmp(argv[0], "none") != 0) {
|
||||||
list_t *split = split_string(argv[0], "+");
|
list_t *split = split_string(argv[0], "+");
|
||||||
for (int i = 0; i < split->length; ++i) {
|
for (int i = 0; i < split->length; ++i) {
|
||||||
uint32_t tmp_mod;
|
uint32_t tmp_mod;
|
||||||
if ((tmp_mod = get_modifier_mask_by_name(split->items[i])) > 0) {
|
if ((tmp_mod = get_modifier_mask_by_name(split->items[i])) > 0) {
|
||||||
mod |= tmp_mod;
|
mod |= tmp_mod;
|
||||||
|
} else if (strcmp(split->items[i], "none") == 0) {
|
||||||
|
error = cmd_results_new(CMD_INVALID,
|
||||||
|
"none cannot be used along with other modifiers");
|
||||||
|
list_free_items_and_destroy(split);
|
||||||
|
return error;
|
||||||
} else {
|
} else {
|
||||||
error = cmd_results_new(CMD_INVALID,
|
error = cmd_results_new(CMD_INVALID,
|
||||||
"Unknown modifier '%s'", (char *)split->items[i]);
|
"Unknown modifier '%s'", (char *)split->items[i]);
|
||||||
|
@ -28,6 +34,7 @@ struct cmd_results *bar_cmd_modifier(int argc, char **argv) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
list_free_items_and_destroy(split);
|
list_free_items_and_destroy(split);
|
||||||
|
}
|
||||||
config->current_bar->modifier = mod;
|
config->current_bar->modifier = mod;
|
||||||
sway_log(SWAY_DEBUG,
|
sway_log(SWAY_DEBUG,
|
||||||
"Show/Hide the bar when pressing '%s' in hide mode.", argv[0]);
|
"Show/Hide the bar when pressing '%s' in hide mode.", argv[0]);
|
||||||
|
|
|
@ -425,7 +425,8 @@ static void determine_bar_visibility(uint32_t modifiers) {
|
||||||
for (int i = 0; i < config->bars->length; ++i) {
|
for (int i = 0; i < config->bars->length; ++i) {
|
||||||
struct bar_config *bar = config->bars->items[i];
|
struct bar_config *bar = config->bars->items[i];
|
||||||
if (strcmp(bar->mode, bar->hidden_state) == 0) { // both are "hide"
|
if (strcmp(bar->mode, bar->hidden_state) == 0) { // both are "hide"
|
||||||
bool should_be_visible = (~modifiers & bar->modifier) == 0;
|
bool should_be_visible =
|
||||||
|
bar->modifier != 0 && (~modifiers & bar->modifier) == 0;
|
||||||
if (bar->visible_by_modifier != should_be_visible) {
|
if (bar->visible_by_modifier != should_be_visible) {
|
||||||
bar->visible_by_modifier = should_be_visible;
|
bar->visible_by_modifier = should_be_visible;
|
||||||
ipc_event_bar_state_update(bar);
|
ipc_event_bar_state_update(bar);
|
||||||
|
|
Loading…
Reference in a new issue