X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fstacking.h;h=ded4644ebb13d791b3df1da57e58c42312bcf2f6;hb=775d5da7ade2d184dfcef5c046b8d39f91804f01;hp=70e4b2d4e3a81bc470fba56edd9e71137269fe0f;hpb=98304406432cda3a94c2a57f0812714a229ec77a;p=chaz%2Fopenbox diff --git a/openbox/stacking.h b/openbox/stacking.h index 70e4b2d4..ded4644e 100644 --- a/openbox/stacking.h +++ b/openbox/stacking.h @@ -27,6 +27,7 @@ /*! The possible stacking layers a client window can be a part of */ typedef enum { + OB_STACKING_LAYER_INVALID, OB_STACKING_LAYER_DESKTOP, /*!< 0 - desktop windows */ OB_STACKING_LAYER_BELOW, /*!< 1 - normal windows w/ below */ OB_STACKING_LAYER_NORMAL, /*!< 2 - normal windows */ @@ -59,9 +60,18 @@ void stacking_lower(ObWindow *window); */ void stacking_below(ObWindow *window, ObWindow *below); -/*! Returns TRUE if client is occluded by sibling. If sibling is NULL it tries - against all other clients. Otherwise, it returns FALSE. +/*! Restack a window based upon a sibling (or all windows) in various ways. + @param client The client to be restacked + @param sibling Another client to compare to, or NULL to compare to all + windows + @param detail One of Above, Below, TopIf, BottomIf, Opposite + @param activate If TRUE, and if the window is going to be raised, it will + be activated instead + See http://tronche.com/gui/x/xlib/window/configure.html for details on + how each detail works with and without a sibling. */ -gboolean stacking_occluded(struct _ObClient *client,struct _ObClient *sibling); +void stacking_restack_request(struct _ObClient *client, + struct _ObClient *sibling, + gint detail, gboolean); #endif