2019-12-15 21:10:30 +00:00
|
|
|
/** Function to shift the current view to the left/right
|
|
|
|
*
|
|
|
|
* @param: "arg->i" stores the number of tags to shift right (positive value)
|
|
|
|
* or left (negative value)
|
|
|
|
*/
|
|
|
|
void
|
2020-03-29 15:36:20 +00:00
|
|
|
shiftview(const Arg *arg)
|
|
|
|
{
|
|
|
|
Arg a;
|
|
|
|
Client *c;
|
|
|
|
unsigned visible = 0;
|
|
|
|
int i = arg->i;
|
|
|
|
int count = 0;
|
|
|
|
int nextseltags, curseltags = selmon->tagset[selmon->seltags];
|
2019-12-15 21:10:30 +00:00
|
|
|
|
2020-03-29 15:36:20 +00:00
|
|
|
do {
|
|
|
|
if(i > 0) // left circular shift
|
|
|
|
nextseltags = (curseltags << i) | (curseltags >> (LENGTH(tags) - i));
|
2019-12-15 21:10:30 +00:00
|
|
|
|
2020-03-29 15:36:20 +00:00
|
|
|
else // right circular shift
|
|
|
|
nextseltags = curseltags >> (- i) | (curseltags << (LENGTH(tags) + i));
|
2019-12-15 21:10:30 +00:00
|
|
|
|
2020-03-29 15:36:20 +00:00
|
|
|
// Check if tag is visible
|
|
|
|
for (c = selmon->clients; c && !visible; c = c->next)
|
|
|
|
if (nextseltags & c->tags) {
|
|
|
|
visible = 1;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
i += arg->i;
|
|
|
|
} while (!visible && ++count < 10);
|
|
|
|
|
|
|
|
if (count < 10) {
|
|
|
|
a.i = nextseltags;
|
|
|
|
view(&a);
|
|
|
|
}
|
2019-12-15 21:10:30 +00:00
|
|
|
}
|