X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=9bd4f206e90a900611191b01fbcad2ec06a45358;hb=209d8df0b15702b523862f1717e055350a34c812;hp=e6606dd5968c4c8a19d09647489b9bf5eababaf5;hpb=c4e4760c41f10aae6af19a4363cb247c71edee4b;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index e6606dd5..9bd4f206 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -1,7 +1,8 @@ -/* -*- indent-tabs-mode: t; tab-width: 4; c-basic-offset: 4; -*- +/* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*- focus.h for the Openbox window manager - Copyright (c) 2003 Ben Jansens + Copyright (c) 2006 Mikael Magnusson + 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 @@ -28,11 +29,9 @@ 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; +extern GList *focus_order; void focus_startup(gboolean reconfig); void focus_shutdown(gboolean reconfig); @@ -41,20 +40,11 @@ void focus_shutdown(gboolean reconfig); send focus anywhere, its called by the Focus event handlers */ void focus_set_client(struct _ObClient *client); -typedef enum { - OB_FOCUS_FALLBACK_UNFOCUSING, /*!< forcefully remove focus from the - current window */ - OB_FOCUS_FALLBACK_NOFOCUS /*!< nothing has focus for some reason */ -} ObFocusFallbackType; +/*! Focus nothing, but let keyboard events be caught. */ +void focus_nothing(); /*! Call this when you need to focus something! */ -void focus_fallback(ObFocusFallbackType type); - -/*! 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); +struct _ObClient* focus_fallback(gboolean allow_refocus); /*! Add a new client into the focus order */ void focus_order_add_new(struct _ObClient *c); @@ -69,4 +59,6 @@ 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); + #endif