X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=014350f9901c8d2c208aa593cea35e3756b57bc0;hb=3b569880695dec2769616a156299d75d3c5e5d9c;hp=7c67f6cb202a8d7bd0e26f354b9684657c290e3e;hpb=16f46c296d1fcd3f27fc62a18e71c55fb3fd3e88;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index 7c67f6cb..014350f9 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -28,6 +28,10 @@ struct _ObClient; /*! The client which is currently focused */ extern struct _ObClient *focus_client; +/*! The client which is being decorated as focused, not always matching the + real focus, but this is used to track it so that it can be ersolved to match +*/ +extern struct _ObClient *focus_hilite; /*! The client which appears focused during a focus cycle operation */ extern struct _ObClient *focus_cycle_target; @@ -44,17 +48,21 @@ void focus_set_client(struct _ObClient *client); typedef enum { OB_FOCUS_FALLBACK_UNFOCUSING, /*!< forcefully remove focus from the current window */ + OB_FOCUS_FALLBACK_CLOSED, /*!< closed the window with focus */ OB_FOCUS_FALLBACK_NOFOCUS /*!< nothing has focus for some reason */ } ObFocusFallbackType; +struct _ObClient* focus_fallback_target(ObFocusFallbackType type); + /*! Call this when you need to focus something! */ void focus_fallback(ObFocusFallbackType type); /*! Cycle focus amongst windows. */ -void focus_cycle(gboolean forward, gboolean linear, +void focus_cycle(gboolean forward, gboolean linear, gboolean interactive, gboolean dialog, gboolean done, gboolean cancel); -void focus_directional_cycle(ObDirection dir, +void focus_directional_cycle(ObDirection dir, gboolean interactive, gboolean dialog, gboolean done, gboolean cancel); +void focus_cycle_draw_indicator(); /*! Add a new client into the focus order */ void focus_order_add_new(struct _ObClient *c);