X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fstacking.h;h=bf2f56b48be2dfc59e5e76cd9f787251be0be298;hb=f869ec5121afaf74ff3a7a420923878c093f9c08;hp=2ad3677d2915f646ae8b00b125220f09ddb21997;hpb=c4e4760c41f10aae6af19a4363cb247c71edee4b;p=chaz%2Fopenbox diff --git a/openbox/stacking.h b/openbox/stacking.h index 2ad3677d..bf2f56b4 100644 --- a/openbox/stacking.h +++ b/openbox/stacking.h @@ -1,7 +1,8 @@ -/* -*- indent-tabs-mode: t; tab-width: 4; c-basic-offset: 4; -*- +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- stacking.h for the Openbox window manager - Copyright (c) 2003 Ben Jansens + Copyright (c) 2006 Mikael Magnusson + Copyright (c) 2003-2007 Dana Jansens This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -26,13 +27,13 @@ /*! The possible stacking layers a client window can be a part of */ typedef enum { - OB_STACKING_LAYER_DESKTOP, /*!< 0 - desktop windows */ - OB_STACKING_LAYER_BELOW, /*!< 1 - normal windows w/ below */ - OB_STACKING_LAYER_NORMAL, /*!< 2 - normal windows */ - OB_STACKING_LAYER_ABOVE, /*!< 3 - normal windows w/ above */ - OB_STACKING_LAYER_TOP, /*!< 4 - always-on-top-windows (docks?) */ - OB_STACKING_LAYER_FULLSCREEN, /*!< 5 - fullscreeen windows */ - OB_STACKING_LAYER_INTERNAL, /*!< 6 - openbox windows/menus */ + 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 */ + OB_STACKING_LAYER_ABOVE, /*!< 3 - normal windows w/ above */ + OB_STACKING_LAYER_FULLSCREEN, /*!< 4 - fullscreeen windows */ + OB_STACKING_LAYER_INTERNAL, /*!< 5 - openbox windows/menus */ OB_NUM_STACKING_LAYERS } ObStackingLayer; @@ -59,4 +60,19 @@ void stacking_lower(ObWindow *window); */ void stacking_below(ObWindow *window, ObWindow *below); +/*! 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 + @return TRUE if the client was restacked + See http://tronche.com/gui/x/xlib/window/configure.html for details on + how each detail works with and without a sibling. +*/ +gboolean stacking_restack_request(struct _ObClient *client, + struct _ObClient *sibling, + gint detail, gboolean activate); + #endif