X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;ds=sidebyside;f=openbox%2Ffocus.h;h=1b1ce066c337930b595fea37951c10c51e5b2bea;hb=fcdcd0fab4141d2d8bc1c156096ac5dbedbeaf61;hp=9db5202696f806fbf63d97ff24196b7b41ae04e3;hpb=f8a47de5ec444c452093371e3db16857eb39a490;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index 9db52026..1b1ce066 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -1,20 +1,54 @@ #ifndef __focus_h #define __focus_h -#include +#include "misc.h" -struct Client; +#include +#include -/*! The window which gets focus when nothing else will be focused */ -extern Window focus_backup; +struct _ObClient; /*! The client which is currently focused */ -extern struct Client *focus_client; +extern struct _ObClient *focus_client; + +/*! The recent focus order on each desktop */ +extern GList **focus_order; -void focus_startup(); +void focus_startup(gboolean reconfig); +void focus_shutdown(gboolean reconfig); /*! Specify which client is currently focused, this doesn't actually send focus anywhere, its called by the Focus event handlers */ -void focus_set_client(struct Client *client); +void focus_set_client(struct _ObClient *client); + +typedef enum { + OB_FOCUS_FALLBACK_DESKTOP, /*!< switching desktops */ + OB_FOCUS_FALLBACK_UNFOCUSING, /*!< forcefully remove focus from the + current window */ + OB_FOCUS_FALLBACK_NOFOCUS /*!< nothing has focus for some reason */ +} ObFocusFallbackType; + +/*! Call this when you need to focus something! */ +void focus_fallback(ObFocusFallbackType type); + +/*! Cycle focus amongst windows + Returns the _ObClient to which focus has been cycled, or NULL if none. */ +void focus_cycle(gboolean forward, gboolean linear, + gboolean dialog, gboolean done, gboolean cancel); +void focus_directional_cycle(ObDirection dir, + gboolean dialog, gboolean done, gboolean cancel); + +/*! Add a new client into the focus order */ +void focus_order_add_new(struct _ObClient *c); + +/*! Remove a client from the focus order */ +void focus_order_remove(struct _ObClient *c); + +/*! Move a client to the top of the focus order */ +void focus_order_to_top(struct _ObClient *c); + +/*! Move a client to the bottom of the focus order (keeps iconic windows at the + very bottom always though). */ +void focus_order_to_bottom(struct _ObClient *c); #endif