aboutsummaryrefslogtreecommitdiff
path: root/sway/container.c
diff options
context:
space:
mode:
authorDrew DeVault <sir@cmpwn.com>2015-08-22 11:18:55 -0400
committerDrew DeVault <sir@cmpwn.com>2015-08-22 11:18:55 -0400
commitb7f4607544d51811e986b98c8c3eda7ed7c68b1a (patch)
tree0e2cf9f02e1d2cde3bf7d0b7424ff5ac3ee6c1e3 /sway/container.c
parentade634bb04027a6ea5f053330e044638f135c147 (diff)
Implement output configuration through config
Do not use `output res WIDTHxHEIGHT` yet, wlc has issues with it (cc @Cloudef)
Diffstat (limited to 'sway/container.c')
-rw-r--r--sway/container.c25
1 files changed, 21 insertions, 4 deletions
diff --git a/sway/container.c b/sway/container.c
index 62ff1c4a..7f6fcbc6 100644
--- a/sway/container.c
+++ b/sway/container.c
@@ -55,13 +55,31 @@ static void free_swayc(swayc_t *cont) {
// New containers
swayc_t *new_output(wlc_handle handle) {
- const struct wlc_size* size = wlc_output_get_resolution(handle);
+ const struct wlc_size *size = wlc_output_get_resolution(handle);
const char *name = wlc_output_get_name(handle);
sway_log(L_DEBUG, "Added output %lu:%s", handle, name);
+ struct output_config *oc ;
+ int i;
+ for (i = 0; i < config->output_configs->length; ++i) {
+ oc = config->output_configs->items[i];
+ if (strcasecmp(name, oc->name) == 0) {
+ sway_log(L_DEBUG, "Matched output config for %s", name);
+ break;
+ }
+ oc = NULL;
+ }
+
swayc_t *output = new_swayc(C_OUTPUT);
- output->width = size->w;
- output->height = size->h;
+ if (oc && oc->width != -1 && oc->height != -1) {
+ output->width = oc->width;
+ output->height = oc->height;
+ struct wlc_size new_size = { .w = oc->width, .h = oc->width };
+ wlc_output_set_resolution(handle, &new_size);
+ } else {
+ output->width = size->w;
+ output->height = size->h;
+ }
output->handle = handle;
output->name = name ? strdup(name) : NULL;
output->gaps = config->gaps_outer + config->gaps_inner / 2;
@@ -71,7 +89,6 @@ swayc_t *new_output(wlc_handle handle) {
// Create workspace
char *ws_name = NULL;
if (name) {
- int i;
for (i = 0; i < config->workspace_outputs->length; ++i) {
struct workspace_output *wso = config->workspace_outputs->items[i];
if (strcasecmp(wso->output, name) == 0) {