From 2f0f8b16c2755165fc79c5801aedff0428ef03ad Mon Sep 17 00:00:00 2001 From: lebenlechzer Date: Sun, 12 Mar 2017 21:17:12 +0100 Subject: [PATCH] i3bar: accept 'primary' for output config option --- docs/userguide | 14 +++++++++++++- i3bar/src/ipc.c | 8 +++++++- i3bar/src/outputs.c | 11 ++++++----- 3 files changed, 26 insertions(+), 7 deletions(-) diff --git a/docs/userguide b/docs/userguide index 40e9e3b9..4946a1ba 100644 --- a/docs/userguide +++ b/docs/userguide @@ -1378,7 +1378,7 @@ directive multiple times. *Syntax*: --------------- -output +output primary| --------------- *Example*: @@ -1400,7 +1400,19 @@ bar { statusline #ffffff } } + +# show bar on the primary monitor and on HDMI2 +bar { + output primary + output HDMI2 + status_command i3status +} + ------------------------------- +Note that you might not have a primary output configured yet. To do so, run: +------------------------- +xrandr --output --primary +------------------------- === Tray output diff --git a/i3bar/src/ipc.c b/i3bar/src/ipc.c index cc5074e5..459684ef 100644 --- a/i3bar/src/ipc.c +++ b/i3bar/src/ipc.c @@ -63,12 +63,18 @@ void got_subscribe_reply(char *reply) { * */ void got_output_reply(char *reply) { + DLOG("Clearing old output configuration...\n"); + i3_output *o_walk; + SLIST_FOREACH(o_walk, outputs, slist) { + destroy_window(o_walk); + } + FREE_SLIST(outputs, i3_output); + DLOG("Parsing outputs JSON...\n"); parse_outputs_json(reply); DLOG("Reconfiguring windows...\n"); reconfig_windows(false); - i3_output *o_walk; SLIST_FOREACH(o_walk, outputs, slist) { kick_tray_clients(o_walk); } diff --git a/i3bar/src/outputs.c b/i3bar/src/outputs.c index 480c00be..e7cd6eeb 100644 --- a/i3bar/src/outputs.c +++ b/i3bar/src/outputs.c @@ -189,11 +189,12 @@ static int outputs_end_map_cb(void *params_) { if (config.num_outputs > 0) { bool handle_output = false; for (int c = 0; c < config.num_outputs; c++) { - if (strcasecmp(params->outputs_walk->name, config.outputs[c]) != 0) - continue; - - handle_output = true; - break; + if (strcasecmp(params->outputs_walk->name, config.outputs[c]) == 0 || + (strcasecmp(config.outputs[c], "primary") == 0 && + params->outputs_walk->primary)) { + handle_output = true; + break; + } } if (!handle_output) { DLOG("Ignoring output \"%s\", not configured to handle it.\n",