opt: optimize focusmon

This commit is contained in:
DreamMaoMao 2025-03-30 18:57:32 +08:00
parent 26dc1995d5
commit 2ab0da9cfa

View file

@ -4905,8 +4905,9 @@ 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)
@ -4916,19 +4917,15 @@ setmon(Client *c, Monitor *m, uint32_t newtags) {
/* 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
: m->tagset[m->seltags]; /* assign tags of target monitor */
setfloating(c, c->isfloating);
setfullscreen(c, c->isfullscreen); /* This will call arrange(c->mon) */ setfullscreen(c, c->isfullscreen); /* This will call arrange(c->mon) */
if(c && VISIBLEON(c, c->mon)) setfloating(c, c->isfloating);
focusclient(c,1);
} }
focusclient(focustop(selmon), 1);
} }
void // 17 void // 17