opt: optimize focusmon
This commit is contained in:
41
maomao.c
41
maomao.c
@@ -4905,30 +4905,27 @@ void setsmfact(const Arg *arg) {
|
|||||||
arrange(selmon, false);
|
arrange(selmon, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void // 0.5
|
void
|
||||||
setmon(Client *c, Monitor *m, uint32_t newtags) {
|
setmon(Client *c, Monitor *m, uint32_t newtags)
|
||||||
Monitor *oldmon = c->mon;
|
{
|
||||||
|
Monitor *oldmon = c->mon;
|
||||||
|
|
||||||
if (oldmon == m)
|
if (oldmon == m)
|
||||||
return;
|
return;
|
||||||
c->mon = m;
|
c->mon = m;
|
||||||
c->prev = c->geom;
|
c->prev = c->geom;
|
||||||
|
|
||||||
/* Scene graph sends surface leave/enter events on move and resize */
|
/* Scene graph sends surface leave/enter events on move and resize */
|
||||||
if (oldmon)
|
if (oldmon)
|
||||||
arrange(oldmon, false);
|
arrange(oldmon,false);
|
||||||
if (m) {
|
if (m) {
|
||||||
/* Make sure window actually overlaps with the monitor */
|
/* Make sure window actually overlaps with the monitor */
|
||||||
resize(c, c->geom, 0);
|
resize(c, c->geom, 0);
|
||||||
c->tags = newtags
|
c->tags = newtags ? newtags : m->tagset[m->seltags]; /* assign tags of target monitor */
|
||||||
? newtags
|
setfullscreen(c, c->isfullscreen); /* This will call arrange(c->mon) */
|
||||||
: m->tagset[m->seltags]; /* assign tags of target monitor */
|
setfloating(c, c->isfloating);
|
||||||
setfloating(c, c->isfloating);
|
}
|
||||||
setfullscreen(c, c->isfullscreen); /* This will call arrange(c->mon) */
|
focusclient(focustop(selmon), 1);
|
||||||
if(c && VISIBLEON(c, c->mon))
|
|
||||||
focusclient(c,1);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void // 17
|
void // 17
|
||||||
|
|||||||
Reference in New Issue
Block a user