From 2555207b578767c0dfbac916776625a1fc892fe4 Mon Sep 17 00:00:00 2001 From: Palanix Date: Mon, 26 Feb 2024 19:27:39 +0100 Subject: [PATCH] Update monfig --- monfig/monfig.patch | 62 +++++++++++++++++++++++++-------------------- 1 file changed, 35 insertions(+), 27 deletions(-) diff --git a/monfig/monfig.patch b/monfig/monfig.patch index 5eeaa1f..4aa945d 100644 --- a/monfig/monfig.patch +++ b/monfig/monfig.patch @@ -1,4 +1,4 @@ -From 00d302a8196fd4d8d006d78c10e08014b220403e Mon Sep 17 00:00:00 2001 +From e43e79b7974b34786c9d3cc7b02952e7a1cd50a0 Mon Sep 17 00:00:00 2001 From: Palanix Date: Mon, 4 Apr 2022 16:08:29 +0200 Subject: [PATCH] Updated patch now allowing setting x and y @@ -8,64 +8,72 @@ Content-Transfer-Encoding: 8bit Co-authored-by: Leonardo Hernández Hernández 0 otherwise you will not have a displayed screen. ++ { NULL, 0.55f, 1, 1, &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, 0, 0, 0, 0, 0.0f, 0 ,1}, ++ // mode let's the user decide on how dwl should implement the modes: ++ // -1 Sets a custom mode following the users choice ++ // All other number's set the mode at the index n, 0 is the standard mode; see wlr-randr }; /* keyboard */ diff --git a/dwl.c b/dwl.c -index fa76db2..ef2d2f1 100644 +index fa76db2..52d210c 100644 --- a/dwl.c +++ b/dwl.c -@@ -212,6 +212,10 @@ typedef struct { +@@ -212,6 +212,11 @@ typedef struct { const Layout *lt; enum wl_output_transform rr; int x, y; + int resx; + int resy; + float rate; ++ int mode; + int adaptive; } MonitorRule; typedef struct { -@@ -876,15 +880,19 @@ createmon(struct wl_listener *listener, void *data) +@@ -848,6 +853,7 @@ createmon(struct wl_listener *listener, void *data) + /* This event is raised by the backend when a new output (aka a display or + * monitor) becomes available. */ + struct wlr_output *wlr_output = data; ++ struct wlr_output_mode *mode = wl_container_of(wlr_output->modes.next, mode, link); + const MonitorRule *r; + size_t i; + struct wlr_output_state state; +@@ -876,15 +882,23 @@ createmon(struct wl_listener *listener, void *data) strncpy(m->ltsymbol, m->lt[m->sellt]->symbol, LENGTH(m->ltsymbol)); wlr_output_state_set_scale(&state, r->scale); wlr_output_state_set_transform(&state, r->rr); + -+ if(r->name) ++ if(r->mode == -1) + wlr_output_state_set_custom_mode(&state, r->resx, r->resy, -+ r->rate > 0 ? (int)(r->rate * 1000) : 0); -+ else -+ wlr_output_state_set_mode(&state, wlr_output_preferred_mode(wlr_output)); ++ (int) (r->rate > 0 ? r->rate * 1000 : 0)); ++ else { ++ for (int j = 0; j < r->mode; j++) { ++ mode = wl_container_of(mode->link.next, mode, link); ++ } ++ wlr_output_state_set_mode(&state, mode); ++ } + + wlr_output_state_set_adaptive_sync_enabled(&state, r->adaptive); break; @@ -82,5 +90,5 @@ index fa76db2..ef2d2f1 100644 /* Set up event listeners */ LISTEN(&wlr_output->events.frame, &m->frame, rendermon); -- -2.43.2 +2.44.0