X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=4f37b7281fce234a4850b0967a9f2efa4f1b14dc;hb=435df32acc55a3bc4cc8f9ba954ae21b65c7c69d;hp=200d96a57043c3bd2aca6355d7d0a3d81040923a;hpb=a9175a8a324deb6d1b7e717fb77fbc96204c7540;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index 200d96a5..4f37b728 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -2,7 +2,7 @@ focus.h for the Openbox window manager Copyright (c) 2006 Mikael Magnusson - Copyright (c) 2003 Ben Jansens + Copyright (c) 2003-2007 Dana 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 @@ -29,19 +29,9 @@ 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 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(gboolean reconfig); void focus_shutdown(gboolean reconfig); @@ -50,19 +40,14 @@ void focus_shutdown(gboolean reconfig); send focus anywhere, its called by the Focus event handlers */ void focus_set_client(struct _ObClient *client); -struct _ObClient* focus_fallback_target(gboolean allow_refocus, - struct _ObClient *old); +/*! Focus nothing, but let keyboard events be caught. */ +void focus_nothing(void); /*! 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, Time time); -void focus_directional_cycle(ObDirection dir, gboolean interactive, - gboolean dialog, gboolean done, gboolean cancel, - Time time); -void focus_cycle_draw_indicator(); +struct _ObClient* focus_fallback(gboolean allow_refocus, + gboolean allow_pointer, + gboolean allow_omnipresent, + gboolean focus_lost); /*! Add a new client into the focus order */ void focus_order_add_new(struct _ObClient *c); @@ -77,4 +62,13 @@ void focus_order_to_top(struct _ObClient *c); very bottom always though). */ void focus_order_to_bottom(struct _ObClient *c); +struct _ObClient *focus_order_find_first(guint desktop); + +gboolean focus_valid_target(struct _ObClient *ft, + gboolean helper_windows, + gboolean iconic_windows, + gboolean all_desktops, + gboolean dock_windows, + gboolean desktop_windows); + #endif