X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=0caec776b760ad7da77c1e2214fd029f53e4a540;hb=4be58bf13719fd22cb08a7f016eaf757640ccd05;hp=cfaba39b78e1457d08b7e7d2bd10b402f027efe9;hpb=2c6c0757fa497f4c1e0648bcbb1927c0fa12862f;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index cfaba39b..0caec776 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -1,6 +1,8 @@ #ifndef __focus_h #define __focus_h +#include "misc.h" + #include #include @@ -8,12 +10,14 @@ struct _ObClient; /*! The client which is currently focused */ extern struct _ObClient *focus_client; +/*! The client which appears focused during a focus cycle operation */ +extern struct _ObClient *focus_cycle_target; /*! The recent focus order on each desktop */ extern GList **focus_order; -void focus_startup(); -void focus_shutdown(); +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 */ @@ -29,10 +33,11 @@ typedef enum { /*! 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. */ -struct _ObClient *focus_cycle(gboolean forward, gboolean linear, - gboolean dialog, gboolean done, gboolean cancel); +/*! Cycle focus amongst windows. */ +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);