X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=d917367bed1d3e7e299d3fff102d0ea70a864231;hb=7d943a950e39d4d93113c0efc7b41916f6b8c66d;hp=cb9a9a99b4f87b4ad8aac6787e3d1a3edbd57b8d;hpb=648c55b829e09c66222a9bbf08d10434622feae2;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index cb9a9a99..d917367b 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -4,13 +4,13 @@ #include #include -struct Client; +struct _ObClient; /*! The window which gets focus when nothing else will be focused */ extern Window focus_backup; /*! 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; @@ -20,6 +20,33 @@ void focus_shutdown(); /*! 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 { + Fallback_Desktop, /* switching desktops */ + Fallback_Unfocusing, /* forcefully remove focus from the current window */ + Fallback_NoFocus /* nothing has focus for some reason */ +} FallbackType; + +/*! Call this when you need to focus something! */ +void focus_fallback(FallbackType type); + +/*! Cycle focus amongst windows + Returns the _ObClient to which focus has been cycled, or NULL if none. */ +struct _ObClient *focus_cycle(gboolean forward, gboolean linear, 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