/*
* ion/ioncore/detach.c
*
- * Copyright (c) Tuomo Valkonen 1999-2007.
+ * Copyright (c) Tuomo Valkonen 1999-2009.
*
* See the included file LICENSE for details.
*/
}
if(framemode!=FRAME_MODE_UNKNOWN){
+ /* TODO: remove/obsolete this special case */
WFramedParam fpa=FRAMEDPARAM_INIT;
fpa.mode=framemode;
}else{
WStacking *st=ioncore_find_stacking(reg);
+ ap.level_set=TRUE;
+ ap.level=framelevel+1;
+
if(st!=NULL){
ap.szplcy=st->szplcy;
ap.szplcy_set=TRUE;
- ap.level_set=TRUE;
- ap.level=maxof(st->level, STACKING_LEVEL_NORMAL);
+ /* Hack for modal detached queries, while transients become
+ * non-modal detached.
+ */
+ if(st->level>STACKING_LEVEL_MODAL1)
+ ap.level=st->level;
}
ap.geom_set=TRUE;
void do_unsqueeze(WRegion *reg)
{
WSizeHints h;
- WRegion *mgr=REGION_MANAGER(reg);
if(OBJ_IS(reg, WScreen))
return;
}
ioncore_detach(reg, SETPARAM_SET);
-
- if(REGION_MANAGER(reg)==mgr)
- return;
-
- do_unsqueeze(reg);
}
void ioncore_unsqueeze(WRegion *reg, bool override)
{
if(ioncore_g.unsqueeze_enabled || override)
- do_unsqueeze(region_groupleader_of(reg));
+ do_unsqueeze(reg);
}