X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=4a3f0b1a3c4fa2889514acdd19d68680970813f6;hb=def76092b587e7e9a2b212dc5211773e336525e1;hp=0caec776b760ad7da77c1e2214fd029f53e4a540;hpb=7f8b8119c4a7644e52e579e9d16129c31a761d01;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index 0caec776..4a3f0b1a 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -1,3 +1,21 @@ +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- + + focus.h for the Openbox window manager + Copyright (c) 2003 Ben Jansens + + This program is free software; you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation; either version 2 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + See the COPYING file for a copy of the GNU General Public License. +*/ + #ifndef __focus_h #define __focus_h @@ -10,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; @@ -24,12 +46,13 @@ void focus_shutdown(gboolean reconfig); 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; +struct _ObClient* focus_fallback_target(ObFocusFallbackType type); + /*! Call this when you need to focus something! */ void focus_fallback(ObFocusFallbackType type); @@ -38,6 +61,7 @@ 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); +void focus_cycle_draw_indicator(); /*! Add a new client into the focus order */ void focus_order_add_new(struct _ObClient *c);