Merge pull request #77 from djpohly/use-output-direction
Determine monitor order spatially
This commit is contained in:
		
						commit
						1d7c756107
					
				
							
								
								
									
										10
									
								
								config.def.h
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								config.def.h
									
									
									
									
									
								
							| @ -32,8 +32,6 @@ static const MonitorRule monrules[] = { | |||||||
| 	/* example of a HiDPI laptop monitor:
 | 	/* example of a HiDPI laptop monitor:
 | ||||||
| 	{ "eDP-1",    0.5,  1,      2,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, 0, 0 }, | 	{ "eDP-1",    0.5,  1,      2,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, 0, 0 }, | ||||||
| 	*/ | 	*/ | ||||||
| 	/* the order in which monitors are defined here affects the order in which
 |  | ||||||
| 	 * focusmon and tagmon cycle trough the monitors */ |  | ||||||
| 	/* defaults */ | 	/* defaults */ | ||||||
| 	{ NULL,       0.55, 1,      1,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, 0, 0 }, | 	{ NULL,       0.55, 1,      1,    &layouts[0], WL_OUTPUT_TRANSFORM_NORMAL, 0, 0 }, | ||||||
| }; | }; | ||||||
| @ -87,10 +85,10 @@ static const Key keys[] = { | |||||||
| 	{ MODKEY, 					 XKB_KEY_e,    		togglefullscreen, {0} }, | 	{ MODKEY, 					 XKB_KEY_e,    		togglefullscreen, {0} }, | ||||||
| 	{ MODKEY,                    XKB_KEY_0,          view,           {.ui = ~0} }, | 	{ MODKEY,                    XKB_KEY_0,          view,           {.ui = ~0} }, | ||||||
| 	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_parenright, tag,            {.ui = ~0} }, | 	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_parenright, tag,            {.ui = ~0} }, | ||||||
| 	{ MODKEY,                    XKB_KEY_comma,      focusmon,       {.i = -1} }, | 	{ MODKEY,                    XKB_KEY_comma,      focusmon,       {.i = WLR_DIRECTION_LEFT} }, | ||||||
| 	{ MODKEY,                    XKB_KEY_period,     focusmon,       {.i = +1} }, | 	{ MODKEY,                    XKB_KEY_period,     focusmon,       {.i = WLR_DIRECTION_RIGHT} }, | ||||||
| 	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_less,       tagmon,         {.i = -1} }, | 	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_less,       tagmon,         {.i = WLR_DIRECTION_LEFT} }, | ||||||
| 	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_greater,    tagmon,         {.i = +1} }, | 	{ MODKEY|WLR_MODIFIER_SHIFT, XKB_KEY_greater,    tagmon,         {.i = WLR_DIRECTION_RIGHT} }, | ||||||
| 	TAGKEYS(          XKB_KEY_1, XKB_KEY_exclam,                     0), | 	TAGKEYS(          XKB_KEY_1, XKB_KEY_exclam,                     0), | ||||||
| 	TAGKEYS(          XKB_KEY_2, XKB_KEY_at,                         1), | 	TAGKEYS(          XKB_KEY_2, XKB_KEY_at,                         1), | ||||||
| 	TAGKEYS(          XKB_KEY_3, XKB_KEY_numbersign,                 2), | 	TAGKEYS(          XKB_KEY_3, XKB_KEY_numbersign,                 2), | ||||||
|  | |||||||
							
								
								
									
										35
									
								
								dwl.c
									
									
									
									
									
								
							
							
						
						
									
										35
									
								
								dwl.c
									
									
									
									
									
								
							| @ -176,7 +176,6 @@ struct Monitor { | |||||||
| 	double mfact; | 	double mfact; | ||||||
| 	int nmaster; | 	int nmaster; | ||||||
| 	Client *fullscreenclient; | 	Client *fullscreenclient; | ||||||
| 	int position; |  | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| typedef struct { | typedef struct { | ||||||
| @ -235,7 +234,7 @@ static void cursorframe(struct wl_listener *listener, void *data); | |||||||
| static void destroylayersurfacenotify(struct wl_listener *listener, void *data); | static void destroylayersurfacenotify(struct wl_listener *listener, void *data); | ||||||
| static void destroynotify(struct wl_listener *listener, void *data); | static void destroynotify(struct wl_listener *listener, void *data); | ||||||
| static void destroyxdeco(struct wl_listener *listener, void *data); | static void destroyxdeco(struct wl_listener *listener, void *data); | ||||||
| static Monitor *dirtomon(int dir); | static Monitor *dirtomon(enum wlr_direction dir); | ||||||
| static void focusclient(Client *c, int lift); | static void focusclient(Client *c, int lift); | ||||||
| static void focusmon(const Arg *arg); | static void focusmon(const Arg *arg); | ||||||
| static void focusstack(const Arg *arg); | static void focusstack(const Arg *arg); | ||||||
| @ -830,7 +829,6 @@ createmon(struct wl_listener *listener, void *data) | |||||||
| 	m = wlr_output->data = calloc(1, sizeof(*m)); | 	m = wlr_output->data = calloc(1, sizeof(*m)); | ||||||
| 	m->wlr_output = wlr_output; | 	m->wlr_output = wlr_output; | ||||||
| 	m->tagset[0] = m->tagset[1] = 1; | 	m->tagset[0] = m->tagset[1] = 1; | ||||||
| 	m->position = -1; |  | ||||||
| 	for (r = monrules; r < END(monrules); r++) { | 	for (r = monrules; r < END(monrules); r++) { | ||||||
| 		if (!r->name || strstr(wlr_output->name, r->name)) { | 		if (!r->name || strstr(wlr_output->name, r->name)) { | ||||||
| 			m->mfact = r->mfact; | 			m->mfact = r->mfact; | ||||||
| @ -839,7 +837,6 @@ createmon(struct wl_listener *listener, void *data) | |||||||
| 			wlr_xcursor_manager_load(cursor_mgr, r->scale); | 			wlr_xcursor_manager_load(cursor_mgr, r->scale); | ||||||
| 			m->lt[0] = m->lt[1] = r->lt; | 			m->lt[0] = m->lt[1] = r->lt; | ||||||
| 			wlr_output_set_transform(wlr_output, r->rr); | 			wlr_output_set_transform(wlr_output, r->rr); | ||||||
| 			m->position = r - monrules; |  | ||||||
| 			break; | 			break; | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| @ -848,15 +845,7 @@ createmon(struct wl_listener *listener, void *data) | |||||||
| 	LISTEN(&wlr_output->events.frame, &m->frame, rendermon); | 	LISTEN(&wlr_output->events.frame, &m->frame, rendermon); | ||||||
| 	LISTEN(&wlr_output->events.destroy, &m->destroy, cleanupmon); | 	LISTEN(&wlr_output->events.destroy, &m->destroy, cleanupmon); | ||||||
| 
 | 
 | ||||||
| 	wl_list_for_each(moni, &mons, link) |  | ||||||
| 		if (m->position > moni->position) |  | ||||||
| 			insertmon = moni; |  | ||||||
| 
 |  | ||||||
| 	if (insertmon) /* insertmon is the leftmost monitor to m */ |  | ||||||
| 		wl_list_insert(&insertmon->link, &m->link); |  | ||||||
| 	else |  | ||||||
| 	wl_list_insert(&mons, &m->link); | 	wl_list_insert(&mons, &m->link); | ||||||
| 
 |  | ||||||
| 	wlr_output_enable(wlr_output, 1); | 	wlr_output_enable(wlr_output, 1); | ||||||
| 	if (!wlr_output_commit(wlr_output)) | 	if (!wlr_output_commit(wlr_output)) | ||||||
| 		return; | 		return; | ||||||
| @ -1096,19 +1085,17 @@ fullscreennotify(struct wl_listener *listener, void *data) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| Monitor * | Monitor * | ||||||
| dirtomon(int dir) | dirtomon(enum wlr_direction dir) | ||||||
| { | { | ||||||
| 	Monitor *m; | 	struct wlr_output *next; | ||||||
| 
 | 	if ((next = wlr_output_layout_adjacent_output(output_layout, | ||||||
| 	if (dir > 0) { | 			dir, selmon->wlr_output, selmon->m.x, selmon->m.y))) | ||||||
| 		if (selmon->link.next == &mons) | 		return next->data; | ||||||
| 			return wl_container_of(mons.next, m, link); | 	if ((next = wlr_output_layout_farthest_output(output_layout, | ||||||
| 		return wl_container_of(selmon->link.next, m, link); | 			dir ^ (WLR_DIRECTION_LEFT|WLR_DIRECTION_RIGHT), | ||||||
| 	} else { | 			selmon->wlr_output, selmon->m.x, selmon->m.y))) | ||||||
| 		if (selmon->link.prev == &mons) | 		return next->data; | ||||||
| 			return wl_container_of(mons.prev, m, link); | 	return selmon; | ||||||
| 		return wl_container_of(selmon->link.prev, m, link); |  | ||||||
| 	} |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void | void | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user