Merge pull request #1401 from sideshowdave7/config/add_scale_to_merge_output_config

Fixes to changing scale factor with output command
This commit is contained in:
Drew DeVault 2017-10-14 21:39:39 -04:00
parent d3c2b5f951
commit 8df33198ea

View file

@ -912,6 +912,9 @@ void merge_output_config(struct output_config *dst, struct output_config *src) {
if (src->y != -1) { if (src->y != -1) {
dst->y = src->y; dst->y = src->y;
} }
if (src->scale != -1) {
dst->scale = src->scale;
}
if (src->background) { if (src->background) {
if (dst->background) { if (dst->background) {
free(dst->background); free(dst->background);
@ -1127,7 +1130,7 @@ void apply_output_config(struct output_config *oc, swayc_t *output) {
sway_log(L_DEBUG, "Set %s size to %ix%i (%d)", oc->name, oc->width, oc->height, oc->scale); sway_log(L_DEBUG, "Set %s size to %ix%i (%d)", oc->name, oc->width, oc->height, oc->scale);
struct wlc_size new_size = { .w = oc->width, .h = oc->height }; struct wlc_size new_size = { .w = oc->width, .h = oc->height };
wlc_output_set_resolution(output->handle, &new_size, (uint32_t)oc->scale); wlc_output_set_resolution(output->handle, &new_size, (uint32_t)oc->scale);
} else if (oc && oc->scale != 1) { } else if (oc) {
const struct wlc_size *new_size = wlc_output_get_resolution(output->handle); const struct wlc_size *new_size = wlc_output_get_resolution(output->handle);
wlc_output_set_resolution(output->handle, new_size, (uint32_t)oc->scale); wlc_output_set_resolution(output->handle, new_size, (uint32_t)oc->scale);
} }