X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=1366cd08869e0971ae1c22c4abbcdc7d7b15dd29;hb=4c672be2e1f39e72eb7d7e99f129e61338f481b2;hp=cb9a9a99b4f87b4ad8aac6787e3d1a3edbd57b8d;hpb=648c55b829e09c66222a9bbf08d10434622feae2;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index cb9a9a99..1366cd08 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -1,25 +1,81 @@ +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- + + focus.h for the Openbox window manager + Copyright (c) 2006 Mikael Magnusson + 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 +#include "misc.h" + #include #include -struct Client; - -/*! The window which gets focus when nothing else will be focused */ -extern Window focus_backup; +struct _ObClient; /*! The client which is currently focused */ -extern struct Client *focus_client; +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 resolved to match. + + This is for when you change desktops. We know which window is *going to be* + focused, so we hilight it. But since it's hilighted, we also want + keybindings to go to it, which is really what this is for. +*/ +extern struct _ObClient *focus_hilite; +/*! 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; +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 */ -void focus_set_client(struct Client *client); +void focus_set_client(struct _ObClient *client); + +struct _ObClient* focus_fallback_target(gboolean allow_refocus, + struct _ObClient *old); + +/*! Call this when you need to focus something! */ +void focus_fallback(gboolean allow_refocus); + +/*! Cycle focus amongst windows. */ +void focus_cycle(gboolean forward, gboolean linear, gboolean interactive, + gboolean dialog, gboolean done, gboolean cancel); +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); + +/*! 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); + +struct _ObClient *focus_order_find_first(guint desktop); #endif