X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=ed94fe7885da0d7b3510387cdbf9df096c683017;hb=795d90c3bc57eaf2c98c447f3af5c1c9e7a52fa3;hp=4c8d4c98862d589cad55aea1954f22f228e3681d;hpb=f278ec41e4c310da218563e7d443df32783e26e4;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index 4c8d4c98..ed94fe78 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -15,11 +15,6 @@ extern struct Client *focus_client; /*! The recent focus order on each desktop */ extern GList **focus_order; -/*! Should new windows be focused */ -extern gboolean focus_new; -/*! Focus windows when the mouse enters them */ -extern gboolean focus_follow; - void focus_startup(); void focus_shutdown(); @@ -27,12 +22,31 @@ void focus_shutdown(); send focus anywhere, its called by the Focus event handlers */ void focus_set_client(struct Client *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(gboolean switching_desks); +void focus_fallback(FallbackType type); /*! Cycle focus amongst windows Returns the Client to which focus has been cycled, or NULL if none. */ struct Client *focus_cycle(gboolean forward, gboolean linear, gboolean done, gboolean cancel); +/*! Add a new client into the focus order */ +void focus_order_add_new(struct Client *c); + +/*! Remove a client from the focus order */ +void focus_order_remove(struct Client *c); + +/*! Move a client to the top of the focus order */ +void focus_order_to_top(struct Client *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 Client *c); + #endif