summaryrefslogtreecommitdiffstats
path: root/sway
diff options
context:
space:
mode:
authorLibravatar Brian Ashworth <bosrsf04@gmail.com>2018-06-05 17:56:32 -0400
committerLibravatar Brian Ashworth <bosrsf04@gmail.com>2018-06-06 20:11:24 -0400
commita1b5b93d299bfe129f2b3409a7f642049fcce1d6 (patch)
tree4d87f5ab8f0f18ada1fc12a4eb4ba3b5d0350527 /sway
parentMerge pull request #2116 from RedSoxFan/fix-2113 (diff)
downloadsway-a1b5b93d299bfe129f2b3409a7f642049fcce1d6.tar.gz
sway-a1b5b93d299bfe129f2b3409a7f642049fcce1d6.tar.zst
sway-a1b5b93d299bfe129f2b3409a7f642049fcce1d6.zip
Store sway_outputs so that they can be reenabled
Diffstat (limited to 'sway')
-rw-r--r--sway/commands/output.c29
-rw-r--r--sway/config/output.c2
-rw-r--r--sway/desktop/output.c35
-rw-r--r--sway/ipc-json.c20
-rw-r--r--sway/ipc-server.c9
-rw-r--r--sway/tree/container.c2
-rw-r--r--sway/tree/layout.c1
7 files changed, 85 insertions, 13 deletions
diff --git a/sway/commands/output.c b/sway/commands/output.c
index bc12310e..6c789cc9 100644
--- a/sway/commands/output.c
+++ b/sway/commands/output.c
@@ -1,5 +1,7 @@
1#include "sway/commands.h" 1#include "sway/commands.h"
2#include "sway/config.h" 2#include "sway/config.h"
3#include "sway/output.h"
4#include "sway/tree/layout.h"
3#include "list.h" 5#include "list.h"
4#include "log.h" 6#include "log.h"
5 7
@@ -80,16 +82,25 @@ struct cmd_results *cmd_output(int argc, char **argv) {
80 // will be applied during normal "new output" event from wlroots. 82 // will be applied during normal "new output" event from wlroots.
81 char identifier[128]; 83 char identifier[128];
82 bool all = strcmp(output->name, "*") == 0; 84 bool all = strcmp(output->name, "*") == 0;
83 for (int i = 0; i < root_container.children->length; ++i) { 85 list_t *sway_outputs = root_container.sway_root->outputs;
84 struct sway_container *cont = root_container.children->items[i]; 86 for (int i = 0; i < sway_outputs->length; ++i) {
85 if (cont->type != C_OUTPUT) { 87 struct sway_output *sway_output = sway_outputs->items[i];
86 continue; 88 output_get_identifier(identifier, sizeof(identifier), sway_output);
87 } 89 wlr_log(L_DEBUG, "Checking identifier %s", identifier);
90 if (all || strcmp(sway_output->wlr_output->name, output->name) == 0
91 || strcmp(identifier, output->name) == 0) {
92 if (!sway_output->swayc) {
93 if (!output->enabled) {
94 if (!all) {
95 break;
96 }
97 continue;
98 }
99
100 output_enable(sway_output);
101 }
88 102
89 output_get_identifier(identifier, sizeof(identifier), cont->sway_output); 103 apply_output_config(output, sway_output->swayc);
90 if (all || strcmp(cont->name, output->name) == 0 ||
91 strcmp(identifier, output->name) == 0) {
92 apply_output_config(output, cont);
93 104
94 if (!all) { 105 if (!all) {
95 // Stop looking if the output config isn't applicable to all 106 // Stop looking if the output config isn't applicable to all
diff --git a/sway/config/output.c b/sway/config/output.c
index ee2440ea..648ded27 100644
--- a/sway/config/output.c
+++ b/sway/config/output.c
@@ -131,11 +131,13 @@ void apply_output_config(struct output_config *oc, struct sway_container *output
131 struct wlr_output *wlr_output = output->sway_output->wlr_output; 131 struct wlr_output *wlr_output = output->sway_output->wlr_output;
132 132
133 if (oc && oc->enabled == 0) { 133 if (oc && oc->enabled == 0) {
134 struct sway_output *sway_output = output->sway_output;
134 if (output->sway_output->bg_pid != 0) { 135 if (output->sway_output->bg_pid != 0) {
135 terminate_swaybg(output->sway_output->bg_pid); 136 terminate_swaybg(output->sway_output->bg_pid);
136 output->sway_output->bg_pid = 0; 137 output->sway_output->bg_pid = 0;
137 } 138 }
138 container_destroy(output); 139 container_destroy(output);
140 sway_output->swayc = NULL;
139 wlr_output_layout_remove(root_container.sway_root->output_layout, 141 wlr_output_layout_remove(root_container.sway_root->output_layout,
140 wlr_output); 142 wlr_output);
141 return; 143 return;
diff --git a/sway/desktop/output.c b/sway/desktop/output.c
index acc9caae..5d02f5eb 100644
--- a/sway/desktop/output.c
+++ b/sway/desktop/output.c
@@ -1157,6 +1157,10 @@ void output_damage_whole_container(struct sway_output *output,
1157 wlr_output_damage_add_box(output->damage, &box); 1157 wlr_output_damage_add_box(output->damage, &box);
1158} 1158}
1159 1159
1160static int find_output(const void *output1, const void *output2) {
1161 return output1 == output2 ? 0 : 1;
1162}
1163
1160static void damage_handle_destroy(struct wl_listener *listener, void *data) { 1164static void damage_handle_destroy(struct wl_listener *listener, void *data) {
1161 struct sway_output *output = 1165 struct sway_output *output =
1162 wl_container_of(listener, output, damage_destroy); 1166 wl_container_of(listener, output, damage_destroy);
@@ -1165,7 +1169,19 @@ static void damage_handle_destroy(struct wl_listener *listener, void *data) {
1165 1169
1166static void handle_destroy(struct wl_listener *listener, void *data) { 1170static void handle_destroy(struct wl_listener *listener, void *data) {
1167 struct sway_output *output = wl_container_of(listener, output, destroy); 1171 struct sway_output *output = wl_container_of(listener, output, destroy);
1168 container_destroy(output->swayc); 1172 if (output->swayc) {
1173 container_destroy(output->swayc);
1174 }
1175 int index = list_seq_find(root_container.sway_root->outputs, find_output,
1176 output);
1177 if (index >= 0 && index < root_container.sway_root->outputs->length) {
1178 wlr_log(L_DEBUG, "Removing %s from outputs list",
1179 output->wlr_output->name);
1180 list_del(root_container.sway_root->outputs, index);
1181 wl_list_remove(&output->destroy.link);
1182 output->wlr_output = NULL;
1183 free(output);
1184 }
1169} 1185}
1170 1186
1171static void handle_mode(struct wl_listener *listener, void *data) { 1187static void handle_mode(struct wl_listener *listener, void *data) {
@@ -1203,6 +1219,7 @@ void handle_new_output(struct wl_listener *listener, void *data) {
1203 output->wlr_output = wlr_output; 1219 output->wlr_output = wlr_output;
1204 wlr_output->data = output; 1220 wlr_output->data = output;
1205 output->server = server; 1221 output->server = server;
1222 list_add(root_container.sway_root->outputs, output);
1206 1223
1207 if (!wl_list_empty(&wlr_output->modes)) { 1224 if (!wl_list_empty(&wlr_output->modes)) {
1208 struct wlr_output_mode *mode = 1225 struct wlr_output_mode *mode =
@@ -1210,11 +1227,23 @@ void handle_new_output(struct wl_listener *listener, void *data) {
1210 wlr_output_set_mode(wlr_output, mode); 1227 wlr_output_set_mode(wlr_output, mode);
1211 } 1228 }
1212 1229
1213 output->damage = wlr_output_damage_create(wlr_output); 1230 output_enable(output);
1231}
1232
1233void output_enable(struct sway_output *output) {
1234 struct wlr_output *wlr_output = output->wlr_output;
1235
1236 if (!wlr_output->data) {
1237 wlr_output->data = output;
1238 }
1239
1240 if (!output->damage) {
1241 output->damage = wlr_output_damage_create(wlr_output);
1242 }
1214 1243
1215 output->swayc = output_create(output); 1244 output->swayc = output_create(output);
1216 if (!output->swayc) { 1245 if (!output->swayc) {
1217 free(output); 1246 // Output is disabled
1218 return; 1247 return;
1219 } 1248 }
1220 1249
diff --git a/sway/ipc-json.c b/sway/ipc-json.c
index 6d185449..5d402d1b 100644
--- a/sway/ipc-json.c
+++ b/sway/ipc-json.c
@@ -139,6 +139,26 @@ static void ipc_json_describe_output(struct sway_container *container, json_obje
139 json_object_object_add(object, "layout", json_object_new_string("output")); 139 json_object_object_add(object, "layout", json_object_new_string("output"));
140} 140}
141 141
142json_object *ipc_json_describe_disabled_output(struct sway_output *output) {
143 struct wlr_output *wlr_output = output->wlr_output;
144
145 json_object *object = json_object_new_object();
146
147 json_object_object_add(object, "type", json_object_new_string("output"));
148 json_object_object_add(object, "name",
149 wlr_output->name ? json_object_new_string(wlr_output->name) : NULL);
150 json_object_object_add(object, "active", json_object_new_boolean(false));
151 json_object_object_add(object, "make",
152 json_object_new_string(wlr_output->make));
153 json_object_object_add(object, "model",
154 json_object_new_string(wlr_output->model));
155 json_object_object_add(object, "serial",
156 json_object_new_string(wlr_output->serial));
157 json_object_object_add(object, "modes", json_object_new_array());
158
159 return object;
160}
161
142static void ipc_json_describe_workspace(struct sway_container *workspace, 162static void ipc_json_describe_workspace(struct sway_container *workspace,
143 json_object *object) { 163 json_object *object) {
144 int num = isdigit(workspace->name[0]) ? atoi(workspace->name) : -1; 164 int num = isdigit(workspace->name[0]) ? atoi(workspace->name) : -1;
diff --git a/sway/ipc-server.c b/sway/ipc-server.c
index 8d9ab06a..2a2346b4 100644
--- a/sway/ipc-server.c
+++ b/sway/ipc-server.c
@@ -19,6 +19,7 @@
19#include "sway/commands.h" 19#include "sway/commands.h"
20#include "sway/ipc-json.h" 20#include "sway/ipc-json.h"
21#include "sway/ipc-server.h" 21#include "sway/ipc-server.h"
22#include "sway/output.h"
22#include "sway/server.h" 23#include "sway/server.h"
23#include "sway/input/input-manager.h" 24#include "sway/input/input-manager.h"
24#include "sway/input/seat.h" 25#include "sway/input/seat.h"
@@ -488,6 +489,14 @@ void ipc_client_handle_command(struct ipc_client *client) {
488 ipc_json_describe_container(container)); 489 ipc_json_describe_container(container));
489 } 490 }
490 } 491 }
492 for (int i = 0; i < root_container.sway_root->outputs->length; ++i) {
493 struct sway_output *output =
494 root_container.sway_root->outputs->items[i];
495 if (!output->swayc) {
496 json_object_array_add(outputs,
497 ipc_json_describe_disabled_output(output));
498 }
499 }
491 const char *json_string = json_object_to_json_string(outputs); 500 const char *json_string = json_object_to_json_string(outputs);
492 ipc_send_reply(client, json_string, (uint32_t) strlen(json_string)); 501 ipc_send_reply(client, json_string, (uint32_t) strlen(json_string));
493 json_object_put(outputs); // free 502 json_object_put(outputs); // free
diff --git a/sway/tree/container.c b/sway/tree/container.c
index d0d26631..af965857 100644
--- a/sway/tree/container.c
+++ b/sway/tree/container.c
@@ -255,7 +255,6 @@ static struct sway_container *container_output_destroy(
255 } 255 }
256 } 256 }
257 257
258 wl_list_remove(&output->sway_output->destroy.link);
259 wl_list_remove(&output->sway_output->mode.link); 258 wl_list_remove(&output->sway_output->mode.link);
260 wl_list_remove(&output->sway_output->transform.link); 259 wl_list_remove(&output->sway_output->transform.link);
261 wl_list_remove(&output->sway_output->scale.link); 260 wl_list_remove(&output->sway_output->scale.link);
@@ -265,6 +264,7 @@ static struct sway_container *container_output_destroy(
265 264
266 // clear the wlr_output reference to this container 265 // clear the wlr_output reference to this container
267 output->sway_output->wlr_output->data = NULL; 266 output->sway_output->wlr_output->data = NULL;
267 output->sway_output->swayc = NULL;
268 268
269 wlr_log(L_DEBUG, "OUTPUT: Destroying output '%s'", output->name); 269 wlr_log(L_DEBUG, "OUTPUT: Destroying output '%s'", output->name);
270 _container_destroy(output); 270 _container_destroy(output);
diff --git a/sway/tree/layout.c b/sway/tree/layout.c
index 82502e1b..ce53a515 100644
--- a/sway/tree/layout.c
+++ b/sway/tree/layout.c
@@ -35,6 +35,7 @@ void layout_init(void) {
35 35
36 root_container.sway_root = calloc(1, sizeof(*root_container.sway_root)); 36 root_container.sway_root = calloc(1, sizeof(*root_container.sway_root));
37 root_container.sway_root->output_layout = wlr_output_layout_create(); 37 root_container.sway_root->output_layout = wlr_output_layout_create();
38 root_container.sway_root->outputs = create_list();
38 wl_list_init(&root_container.sway_root->xwayland_unmanaged); 39 wl_list_init(&root_container.sway_root->xwayland_unmanaged);
39 wl_signal_init(&root_container.sway_root->events.new_container); 40 wl_signal_init(&root_container.sway_root->events.new_container);
40 41