X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=ioncore%2Fstacking.c;h=296e054abef0d7720beed73f286b849b8bf02862;hb=69fc8b21b1d40335e5c4223bcc74c26d49202fb2;hp=9c0be9f02686f37db8d94e6a1ff1c84c8f04469e;hpb=d2a43a53786878c1273313249d3b49f6cd559b00;p=ion3.git diff --git a/ioncore/stacking.c b/ioncore/stacking.c index 9c0be9f..296e054 100644 --- a/ioncore/stacking.c +++ b/ioncore/stacking.c @@ -552,7 +552,7 @@ WStacking *stacking_find_to_focus(WStacking *stacking, void *filt_data) { uint min_level=STACKING_LEVEL_BOTTOM; - WStacking *st=NULL; + WStacking *st=NULL, *found=NULL; if(stacking==NULL) return NULL; @@ -572,15 +572,21 @@ WStacking *stacking_find_to_focus(WStacking *stacking, if(st->levellevel>=STACKING_LEVEL_MODAL1) min_level=maxof(min_level, st->level); }while(st!=stacking); - return NULL; + return found; } @@ -590,6 +596,12 @@ static bool mapped_filt(WStacking *st, void *unused) } +static bool mapped_filt_neq(WStacking *st, void *st_neq) +{ + return (st!=(WStacking*)st_neq && mapped_filt(st, NULL)); +} + + static bool mgr_filt(WStacking *st, void *mgr_) { return (st->reg!=NULL && REGION_MANAGER(st->reg)==(WRegion*)mgr_); @@ -616,5 +628,16 @@ uint stacking_min_level_mapped(WStacking *stacking) } +bool stacking_must_focus(WStacking *stacking, WStacking *st) +{ + WStacking *stf=stacking_find_to_focus(stacking, NULL, + mapped_filt_neq, NULL, st); + + return (stf==NULL || + (st->level>stf->level && + st->level>=STACKING_LEVEL_MODAL1)); +} + + /*}}}*/