X-Git-Url: https://git.decadent.org.uk/gitweb/?p=ion3.git;a=blobdiff_plain;f=ioncore%2Fstacking.c;h=9c0be9f02686f37db8d94e6a1ff1c84c8f04469e;hp=9d77ac9489ecd981f68acbfe9e9204a060a0eb2a;hb=ae4260bb64817c11f9a7140324cd3e3ba113e297;hpb=de22e45179cb3bafa490294d31d47f361047a30a diff --git a/ioncore/stacking.c b/ioncore/stacking.c index 9d77ac9..9c0be9f 100644 --- a/ioncore/stacking.c +++ b/ioncore/stacking.c @@ -3,13 +3,11 @@ * * Copyright (c) Tuomo Valkonen 1999-2007. * - * Ion is free software; you can redistribute it and/or modify it under - * the terms of the GNU Lesser General Public License as published by - * the Free Software Foundation; either version 2.1 of the License, or - * (at your option) any later version. + * See the included file LICENSE for details. */ #include +#include #include "common.h" #include "region.h" @@ -32,6 +30,7 @@ WStacking *create_stacking() st->szplcy=SIZEPOLICY_DEFAULT; st->hidden=FALSE; st->lnode=NULL; + st->pseudomodal=FALSE; } return st; @@ -521,8 +520,8 @@ uint stacking_min_level(WStacking *stacking, WStackingFilter *include_filt, void *filt_data) { + uint min_level=STACKING_LEVEL_BOTTOM; WStacking *st=NULL; - uint min_level=0; if(stacking==NULL) return STACKING_LEVEL_BOTTOM; @@ -546,35 +545,39 @@ uint stacking_min_level(WStacking *stacking, } -WStacking *stacking_find_to_focus(WStacking *stacking, WStacking *to_try, +WStacking *stacking_find_to_focus(WStacking *stacking, + WStacking *to_try, WStackingFilter *include_filt, WStackingFilter *approve_filt, void *filt_data) { + uint min_level=STACKING_LEVEL_BOTTOM; WStacking *st=NULL; - uint min_level=0; if(stacking==NULL) return NULL; - min_level=stacking_min_level(stacking, include_filt, filt_data); - - if(to_try!=NULL && to_try->level>=min_level) - return to_try; - st=stacking; do{ st=st->prev; - if(st->levelreg==NULL) + continue; - if(st->reg!=NULL - && !(st->reg->flags®ION_SKIP_FOCUS) - && cf(include_filt, filt_data, st) - && cf(approve_filt, filt_data, st)){ - return st; + if(st!=to_try && (st->reg->flags®ION_SKIP_FOCUS || + !cf(include_filt, filt_data, st))){ + /* skip */ + continue; } + + if(st->levellevel>=STACKING_LEVEL_MODAL1) + min_level=maxof(min_level, st->level); }while(st!=stacking); return NULL;