X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=openbox%2Ffocus.h;h=81cd5ffef92c82d1d75d3b351a41f0432cf51ac6;hb=53109b7592500b71f8c670ea58b0182193ba9a71;hp=4a3f0b1a3c4fa2889514acdd19d68680970813f6;hpb=ff08e38027b9af9a7c5846ab530afbed2fa38d43;p=chaz%2Fopenbox diff --git a/openbox/focus.h b/openbox/focus.h index 4a3f0b1a..81cd5ffe 100644 --- a/openbox/focus.h +++ b/openbox/focus.h @@ -1,6 +1,7 @@ /* -*- 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 @@ -29,7 +30,11 @@ 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 + 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 */ @@ -48,6 +53,7 @@ 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; @@ -57,10 +63,11 @@ struct _ObClient* focus_fallback_target(ObFocusFallbackType type); 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); +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(); /*! Add a new client into the focus order */